1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87
|
// Copyright 2024 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_AI_AI_DATA_KEYED_SERVICE_H_
#define CHROME_BROWSER_AI_AI_DATA_KEYED_SERVICE_H_
#include <optional>
#include <string>
#include <vector>
#include "base/feature_list.h"
#include "base/functional/callback.h"
#include "base/memory/raw_ptr.h"
#include "base/memory/weak_ptr.h"
#include "build/build_config.h"
#include "chrome/common/buildflags.h"
#include "components/keyed_service/core/keyed_service.h"
#include "components/optimization_guide/proto/features/actions_data.pb.h"
#include "components/optimization_guide/proto/features/model_prototyping.pb.h"
#if BUILDFLAG(ENABLE_GLIC)
#include "chrome/browser/actor/execution_engine.h"
#include "chrome/browser/glic/host/context/glic_page_context_fetcher.h"
#include "chrome/common/actor.mojom-forward.h"
#endif
namespace content {
class WebContents;
class BrowserContext;
} // namespace content
// Browser service to collect AI data, including data resulting from triggering
// actor tasks.
class AiDataKeyedService : public KeyedService {
public:
// Data related to AiData collection.
using BrowserData = optimization_guide::proto::BrowserCollectedInformation;
using AiData = std::optional<BrowserData>;
using AiDataCallback = base::OnceCallback<void(AiData)>;
using AiDataSpecifier =
optimization_guide::proto::ModelPrototypingCollectionSpecifier;
explicit AiDataKeyedService(content::BrowserContext* browser_context);
AiDataKeyedService(const AiDataKeyedService&) = delete;
AiDataKeyedService& operator=(const AiDataKeyedService&) = delete;
~AiDataKeyedService() override;
// Returns the list of extensions that are allowlisted for data collection.
static bool IsExtensionAllowlistedForData(const std::string& extension_id);
// Returns the list of extensions that are allowlisted for actions.
static bool IsExtensionAllowlistedForActions(const std::string& extension_id);
// Returns whether an extension is allowed to run on stable channel.
static bool IsExtensionAllowlistedForStable(const std::string& extension_id);
// Fills an AiData and returns the result via the passed in callback. If the
// AiData is empty, data collection failed. |callback| is guaranteed to be
// called, and guaranteed to be called asynchronously. This method uses a set
// of default specifiers. See |GetAiDataWithSpecifiers| for more details.
void GetAiData(int dom_node_id,
content::WebContents* web_contents,
std::string user_input,
AiDataCallback callback,
int tabs_for_inner_text = 10);
// Fills an AiData and returns the result via the passed in callback. If the
// AiData is empty, data collection failed. |callback| is guaranteed to be
// called, and guaranteed to be called asynchronously.
// |tabs_for_inner_text|: The number of tabs to collect inner text for.
void GetAiDataWithSpecifier(content::WebContents* web_contents,
AiDataSpecifier specifier,
AiDataCallback callback);
static const base::Feature& GetAllowlistedAiDataExtensionsFeatureForTesting();
static const base::Feature&
GetAllowlistedActionsExtensionsFeatureForTesting();
private:
// A `KeyedService` should never outlive the `BrowserContext`.
raw_ptr<content::BrowserContext> browser_context_;
base::WeakPtrFactory<AiDataKeyedService> weak_factory_{this};
};
#endif // CHROME_BROWSER_AI_AI_DATA_KEYED_SERVICE_H_
|