blob: 280c2f666f11bb69fb3c11aae4f21c1a3e86d2e1 [file] [log] [blame] [edit]
// Copyright 2018 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_OMNIBOX_BROWSER_DOCUMENT_SUGGESTIONS_SERVICE_H_
#define COMPONENTS_OMNIBOX_BROWSER_DOCUMENT_SUGGESTIONS_SERVICE_H_
#include <memory>
#include <string>
#include "base/memory/raw_ptr.h"
#include "base/memory/scoped_refptr.h"
#include "base/scoped_observation.h"
#include "components/keyed_service/core/keyed_service.h"
#include "components/signin/public/identity_manager/access_token_info.h"
#include "components/signin/public/identity_manager/identity_manager.h"
#include "components/signin/public/identity_manager/tribool.h"
#include "services/network/public/cpp/resource_request.h"
#include "services/network/public/cpp/shared_url_loader_factory.h"
#include "services/network/public/cpp/simple_url_loader.h"
namespace signin {
class PrimaryAccountAccessTokenFetcher;
} // namespace signin
class GoogleServiceAuthError;
// A service to fetch suggestions from a remote endpoint given a URL.
class DocumentSuggestionsService : public KeyedService,
public signin::IdentityManager::Observer {
public:
// null may be passed for params, but no request will be issued.
DocumentSuggestionsService(
signin::IdentityManager* identity_manager,
scoped_refptr<network::SharedURLLoaderFactory> url_loader_factory);
~DocumentSuggestionsService() override;
DocumentSuggestionsService(const DocumentSuggestionsService&) = delete;
DocumentSuggestionsService& operator=(const DocumentSuggestionsService&) =
delete;
using CreationCallback =
base::OnceCallback<void(network::ResourceRequest* request)>;
using StartCallback =
base::OnceCallback<void(std::unique_ptr<network::SimpleURLLoader> loader,
const std::string& request_body)>;
using CompletionCallback =
base::OnceCallback<void(const network::SimpleURLLoader* source,
std::unique_ptr<std::string> response_body)>;
// Returns whether the user's primary account is available.
bool HasPrimaryAccount();
// Test-only method to set the account state to be valid for enabling
// documents suggestions or not.
void SetAccountStateForTesting(bool valid);
// Creates and starts a document suggestion request for |query|.
// May obtain an OAuth2 token for the signed-in user.
void CreateDocumentSuggestionsRequest(const std::u16string& query,
bool is_incognito,
CreationCallback creation_callback,
StartCallback start_callback,
CompletionCallback completion_callback);
// Stops creating the request. Already created requests aren't affected.
void StopCreatingDocumentSuggestionsRequest();
signin::Tribool account_is_workspace_managed() {
return account_is_workspace_managed_;
}
bool should_backoff() { return should_backoff_; }
void set_should_backoff(bool should_backoff) {
should_backoff_ = should_backoff;
}
private:
// Returns whether Enterprise features are applied to the primary account -
// aka Dasher account, obtained from the user account capability.
signin::Tribool IsAccountWorkspaceManaged();
// Called when an access token request completes (successfully or not).
void AccessTokenAvailable(std::unique_ptr<network::ResourceRequest> request,
std::string request_body,
net::NetworkTrafficAnnotationTag traffic_annotation,
StartCallback start_callback,
CompletionCallback completion_callback,
GoogleServiceAuthError error,
signin::AccessTokenInfo access_token_info);
// Activates a loader for |request|, wiring it up to |completion_callback|,
// and calls |start_callback|. If |request_body| isn't empty, it will be
// attached as upload bytes.
void StartDownloadAndTransferLoader(
std::unique_ptr<network::ResourceRequest> request,
std::string request_body,
net::NetworkTrafficAnnotationTag traffic_annotation,
StartCallback start_callback,
CompletionCallback completion_callback);
// signin::IdentityManager::Observer implementation:
void OnPrimaryAccountChanged(
const signin::PrimaryAccountChangeEvent& event_details) override;
void OnExtendedAccountInfoUpdated(const AccountInfo& info) override;
void OnIdentityManagerShutdown(
signin::IdentityManager* identity_manager) override;
scoped_refptr<network::SharedURLLoaderFactory> url_loader_factory_;
raw_ptr<signin::IdentityManager> identity_manager_;
base::ScopedObservation<signin::IdentityManager, DocumentSuggestionsService>
identity_manager_observation_{this};
// Override for HasPrimaryAccount(). For testing only.
bool has_primary_account_for_testing_ = false;
// Override for IsAccountWorkspaceManaged(). For testing only.
bool account_is_workspace_managed_for_testing_ = false;
// Whether the primary account is a Dasher one. Obtained from the user account
// capability. Updated when primary account signin state or capability change.
signin::Tribool account_is_workspace_managed_;
// Helper for fetching OAuth2 access tokens. Non-null when we have a token
// available, or while a token fetch is in progress.
std::unique_ptr<signin::PrimaryAccountAccessTokenFetcher> token_fetcher_;
// Whether the document provider should stop issuing requests.
bool should_backoff_ = false;
};
#endif // COMPONENTS_OMNIBOX_BROWSER_DOCUMENT_SUGGESTIONS_SERVICE_H_