#include "google_apis/gaia/oauth2_mint_token_flow.h"
#include <stddef.h>
#include <optional>
#include <set>
#include <string>
#include <string_view>
#include <vector>
#include "base/command_line.h"
#include "base/containers/span.h"
#include "base/functional/bind.h"
#include "base/json/json_reader.h"
#include "base/metrics/histogram_functions.h"
#include "base/ranges/algorithm.h"
#include "base/strings/escape.h"
#include "base/strings/strcat.h"
#include "base/strings/string_number_conversions.h"
#include "base/strings/string_split.h"
#include "base/strings/string_util.h"
#include "base/strings/stringprintf.h"
#include "base/strings/utf_string_conversions.h"
#include "base/time/time.h"
#include "base/values.h"
#include "google_apis/gaia/gaia_urls.h"
#include "google_apis/gaia/google_service_auth_error.h"
#include "google_apis/gaia/oauth2_api_call_flow.h"
#include "net/base/net_errors.h"
#include "net/cookies/cookie_constants.h"
#include "net/http/http_request_headers.h"
#include "net/http/http_status_code.h"
#include "services/network/public/mojom/url_response_head.mojom.h"
namespace {
const char kValueFalse[] = …;
const char kValueTrue[] = …;
const char kResponseTypeValueNone[] = …;
const char kResponseTypeValueToken[] = …;
const char kOAuth2IssueTokenBodyFormat[] = …;
const char kOAuth2IssueTokenBodyFormatExtensionIdAddendum[] = …;
const char kOAuth2IssueTokenBodyFormatSelectedUserIdAddendum[] = …;
const char kOAuth2IssueTokenBodyFormatDeviceIdAddendum[] = …;
const char kOAuth2IssueTokenBodyFormatConsentResultAddendum[] = …;
const char kIssueAdviceKey[] = …;
const char kIssueAdviceValueRemoteConsent[] = …;
const char kAccessTokenKey[] = …;
const char kExpiresInKey[] = …;
const char kGrantedScopesKey[] = …;
const char kError[] = …;
const char kMessage[] = …;
const char kTokenBindingChallengeHeader[] = …;
constexpr char kTokenBindingResponseKey[] = …;
constexpr char kDirectedResponseKey[] = …;
static GoogleServiceAuthError CreateAuthError(
int net_error,
const network::mojom::URLResponseHead* head,
std::unique_ptr<std::string> body) { … }
std::string FindTokenBindingChallenge(
int net_error,
const network::mojom::URLResponseHead* head) { … }
bool AreCookiesEqual(const net::CanonicalCookie& lhs,
const net::CanonicalCookie& rhs) { … }
void RecordApiCallResult(OAuth2MintTokenApiCallResult result) { … }
}
const char kOAuth2MintTokenApiCallResultHistogram[] = …;
RemoteConsentResolutionData::RemoteConsentResolutionData() = default;
RemoteConsentResolutionData::~RemoteConsentResolutionData() = default;
RemoteConsentResolutionData::RemoteConsentResolutionData(
const RemoteConsentResolutionData& other) = default;
RemoteConsentResolutionData& RemoteConsentResolutionData::operator=(
const RemoteConsentResolutionData& other) = default;
bool RemoteConsentResolutionData::operator==(
const RemoteConsentResolutionData& rhs) const { … }
OAuth2MintTokenFlow::Parameters::Parameters() = default;
OAuth2MintTokenFlow::Parameters
OAuth2MintTokenFlow::Parameters::CreateForExtensionFlow(
std::string_view extension_id,
std::string_view client_id,
base::span<const std::string_view> scopes,
Mode mode,
bool enable_granular_permissions,
std::string_view version,
std::string_view channel,
std::string_view device_id,
std::string_view selected_user_id,
std::string_view consent_result) { … }
OAuth2MintTokenFlow::Parameters
OAuth2MintTokenFlow::Parameters::CreateForClientFlow(
std::string_view client_id,
base::span<const std::string_view> scopes,
std::string_view version,
std::string_view channel,
std::string_view device_id,
std::string_view bound_oauth_token) { … }
OAuth2MintTokenFlow::Parameters::Parameters(Parameters&& other) noexcept =
default;
OAuth2MintTokenFlow::Parameters& OAuth2MintTokenFlow::Parameters::operator=(
Parameters&& other) noexcept = default;
OAuth2MintTokenFlow::Parameters::Parameters(const Parameters& other) = default;
OAuth2MintTokenFlow::Parameters::~Parameters() = default;
OAuth2MintTokenFlow::Parameters OAuth2MintTokenFlow::Parameters::Clone() { … }
OAuth2MintTokenFlow::MintTokenResult::MintTokenResult() = default;
OAuth2MintTokenFlow::MintTokenResult::~MintTokenResult() = default;
OAuth2MintTokenFlow::MintTokenResult::MintTokenResult(
MintTokenResult&& other) noexcept = default;
OAuth2MintTokenFlow::MintTokenResult&
OAuth2MintTokenFlow::MintTokenResult::operator=(
MintTokenResult&& other) noexcept = default;
OAuth2MintTokenFlow::OAuth2MintTokenFlow(Delegate* delegate,
Parameters parameters)
: … { … }
OAuth2MintTokenFlow::~OAuth2MintTokenFlow() = default;
void OAuth2MintTokenFlow::ReportSuccess(const MintTokenResult& result) { … }
void OAuth2MintTokenFlow::ReportRemoteConsentSuccess(
const RemoteConsentResolutionData& resolution_data) { … }
void OAuth2MintTokenFlow::ReportFailure(
const GoogleServiceAuthError& error) { … }
GURL OAuth2MintTokenFlow::CreateApiCallUrl() { … }
net::HttpRequestHeaders OAuth2MintTokenFlow::CreateApiCallHeaders() { … }
std::string OAuth2MintTokenFlow::CreateApiCallBody() { … }
std::string OAuth2MintTokenFlow::CreateAuthorizationHeaderValue(
const std::string& access_token) { … }
void OAuth2MintTokenFlow::ProcessApiCallSuccess(
const network::mojom::URLResponseHead* head,
std::unique_ptr<std::string> body) { … }
void OAuth2MintTokenFlow::ProcessApiCallFailure(
int net_error,
const network::mojom::URLResponseHead* head,
std::unique_ptr<std::string> body) { … }
std::optional<OAuth2MintTokenFlow::MintTokenResult>
OAuth2MintTokenFlow::ParseMintTokenResponse(const base::Value::Dict& dict) { … }
bool OAuth2MintTokenFlow::ParseRemoteConsentResponse(
const base::Value::Dict& dict,
RemoteConsentResolutionData* resolution_data) { … }
net::PartialNetworkTrafficAnnotationTag
OAuth2MintTokenFlow::GetNetworkTrafficAnnotationTag() { … }