blob: c790c0e0ab9644e576daa21080f59f3e1f7a9041 [file] [log] [blame]
// 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_