| // Copyright 2017 The Chromium Authors |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef SERVICES_NETWORK_PUBLIC_CPP_CLIENT_HINTS_H_ |
| #define SERVICES_NETWORK_PUBLIC_CPP_CLIENT_HINTS_H_ |
| |
| #include <stddef.h> |
| |
| #include <array> |
| #include <optional> |
| #include <string> |
| |
| #include "base/component_export.h" |
| #include "base/containers/flat_map.h" |
| #include "base/time/time.h" |
| #include "net/nqe/effective_connection_type.h" |
| #include "services/network/public/mojom/web_client_hints_types.mojom-shared.h" |
| |
| namespace url { |
| class Origin; |
| } // namespace url |
| |
| namespace network { |
| |
| // The "Sec-CH-Prefers-Color-Scheme" header values. |
| COMPONENT_EXPORT(NETWORK_CPP_WEB_PLATFORM) |
| extern const char kPrefersColorSchemeDark[]; |
| COMPONENT_EXPORT(NETWORK_CPP_WEB_PLATFORM) |
| extern const char kPrefersColorSchemeLight[]; |
| |
| // The "Sec-CH-Prefers-Reduced-Motion" header values. |
| COMPONENT_EXPORT(NETWORK_CPP_WEB_PLATFORM) |
| extern const char kPrefersReducedMotionNoPreference[]; |
| COMPONENT_EXPORT(NETWORK_CPP_WEB_PLATFORM) |
| extern const char kPrefersReducedMotionReduce[]; |
| |
| // The "Sec-CH-Prefers-Reduced-Transparency" header values. |
| COMPONENT_EXPORT(NETWORK_CPP_WEB_PLATFORM) |
| extern const char kPrefersReducedTransparencyNoPreference[]; |
| COMPONENT_EXPORT(NETWORK_CPP_WEB_PLATFORM) |
| extern const char kPrefersReducedTransparencyReduce[]; |
| |
| // Mapping from WebEffectiveConnectionType to the header value. This value is |
| // sent to the origins and is returned by the JavaScript API. The ordering |
| // should match the ordering in //net/nqe/effective_connection_type.h and |
| // public/platform/WebEffectiveConnectionType.h. |
| // This array should be updated if either of the enums in |
| // effective_connection_type.h or WebEffectiveConnectionType.h are updated. |
| |
| inline constexpr auto kWebEffectiveConnectionTypeMapping = |
| std::to_array<const char*>({ |
| "4g" /* Unknown */, |
| "4g" /* Offline */, |
| "slow-2g" /* Slow 2G */, |
| "2g" /* 2G */, |
| "3g" /* 3G */, |
| "4g" /* 4G */, |
| }); |
| |
| static_assert(network::kWebEffectiveConnectionTypeMapping.size() == |
| net::EFFECTIVE_CONNECTION_TYPE_4G + 1u); |
| static_assert(network::kWebEffectiveConnectionTypeMapping.size() == |
| static_cast<size_t>(net::EFFECTIVE_CONNECTION_TYPE_LAST)); |
| |
| using ClientHintToNameMap = |
| base::flat_map<network::mojom::WebClientHintsType, std::string>; |
| |
| // Mapping from WebClientHintsType to the hint's name in Accept-CH header. |
| // The ordering matches the ordering of enums in |
| // services/network/public/mojom/web_client_hints_types.mojom |
| COMPONENT_EXPORT(NETWORK_CPP_WEB_PLATFORM) |
| const ClientHintToNameMap& GetClientHintToNameMap(); |
| |
| // Tries to parse an Accept-CH header. Returns std::nullopt if parsing |
| // failed and the header should be ignored; otherwise returns a (possibly |
| // empty) list of hints to accept. |
| std::optional<std::vector<network::mojom::WebClientHintsType>> COMPONENT_EXPORT( |
| NETWORK_CPP_WEB_PLATFORM) ParseClientHintsHeader(const std::string& header); |
| |
| struct COMPONENT_EXPORT(NETWORK_CPP_WEB_PLATFORM) |
| ClientHintToDelegatedThirdPartiesHeader { |
| ClientHintToDelegatedThirdPartiesHeader(); |
| ~ClientHintToDelegatedThirdPartiesHeader(); |
| ClientHintToDelegatedThirdPartiesHeader( |
| const ClientHintToDelegatedThirdPartiesHeader&); |
| |
| base::flat_map<network::mojom::WebClientHintsType, std::vector<url::Origin>> |
| map; |
| bool had_invalid_origins{false}; |
| }; |
| |
| enum class MetaCHType { |
| // This syntax can only activate client hints for the first party origin. |
| // <meta http-equiv="accept-ch" content="Sec-CH-DPR"> |
| // Introduced in M69. |
| HttpEquivAcceptCH, |
| // This syntax can activate and delegate client hints to any origin. |
| // <meta http-equiv="delegate-ch" content="Sec-CH-DPR https://foo.com/"> |
| // Introduced in M105. |
| HttpEquivDelegateCH, |
| }; |
| |
| // Tries to parse an Accept-CH header w/ third-party delegation ability (i.e. a |
| // named meta tag). Returns std::nullopt if parsing failed and the header |
| // should be ignored; otherwise returns a (possibly empty) map of hints to |
| // delegated third-parties. |
| const ClientHintToDelegatedThirdPartiesHeader COMPONENT_EXPORT( |
| NETWORK_CPP_WEB_PLATFORM) |
| ParseClientHintToDelegatedThirdPartiesHeader(const std::string& header, |
| MetaCHType type); |
| |
| // This is used by subclassed of ClientHintsControllerDelegate to track the |
| // amount of time that persisting client hints takes. |
| void COMPONENT_EXPORT(NETWORK_CPP_WEB_PLATFORM) |
| LogClientHintsPersistenceMetrics(const base::TimeTicks& persistence_started, |
| std::size_t hints_stored); |
| |
| } // namespace network |
| |
| #endif // SERVICES_NETWORK_PUBLIC_CPP_CLIENT_HINTS_H_ |