1*6777b538SAndroid Build Coastguard Worker // Copyright 2019 The Chromium Authors 2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be 3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file. 4*6777b538SAndroid Build Coastguard Worker 5*6777b538SAndroid Build Coastguard Worker #ifndef NET_COOKIES_COOKIE_ACCESS_DELEGATE_H_ 6*6777b538SAndroid Build Coastguard Worker #define NET_COOKIES_COOKIE_ACCESS_DELEGATE_H_ 7*6777b538SAndroid Build Coastguard Worker 8*6777b538SAndroid Build Coastguard Worker #include <optional> 9*6777b538SAndroid Build Coastguard Worker 10*6777b538SAndroid Build Coastguard Worker #include "base/containers/flat_map.h" 11*6777b538SAndroid Build Coastguard Worker #include "base/containers/flat_set.h" 12*6777b538SAndroid Build Coastguard Worker #include "base/functional/callback_forward.h" 13*6777b538SAndroid Build Coastguard Worker #include "net/base/net_export.h" 14*6777b538SAndroid Build Coastguard Worker #include "net/base/schemeful_site.h" 15*6777b538SAndroid Build Coastguard Worker #include "net/cookies/canonical_cookie.h" 16*6777b538SAndroid Build Coastguard Worker #include "net/cookies/cookie_constants.h" 17*6777b538SAndroid Build Coastguard Worker #include "net/cookies/cookie_partition_key.h" 18*6777b538SAndroid Build Coastguard Worker #include "net/first_party_sets/first_party_set_entry.h" 19*6777b538SAndroid Build Coastguard Worker #include "net/first_party_sets/first_party_set_metadata.h" 20*6777b538SAndroid Build Coastguard Worker #include "net/first_party_sets/first_party_sets_cache_filter.h" 21*6777b538SAndroid Build Coastguard Worker #include "url/gurl.h" 22*6777b538SAndroid Build Coastguard Worker 23*6777b538SAndroid Build Coastguard Worker namespace net { 24*6777b538SAndroid Build Coastguard Worker 25*6777b538SAndroid Build Coastguard Worker class SchemefulSite; 26*6777b538SAndroid Build Coastguard Worker class SiteForCookies; 27*6777b538SAndroid Build Coastguard Worker 28*6777b538SAndroid Build Coastguard Worker class NET_EXPORT CookieAccessDelegate { 29*6777b538SAndroid Build Coastguard Worker public: 30*6777b538SAndroid Build Coastguard Worker CookieAccessDelegate(); 31*6777b538SAndroid Build Coastguard Worker 32*6777b538SAndroid Build Coastguard Worker CookieAccessDelegate(const CookieAccessDelegate&) = delete; 33*6777b538SAndroid Build Coastguard Worker CookieAccessDelegate& operator=(const CookieAccessDelegate&) = delete; 34*6777b538SAndroid Build Coastguard Worker 35*6777b538SAndroid Build Coastguard Worker virtual ~CookieAccessDelegate(); 36*6777b538SAndroid Build Coastguard Worker 37*6777b538SAndroid Build Coastguard Worker // Returns true if the passed in |url| should be permitted to access secure 38*6777b538SAndroid Build Coastguard Worker // cookies in addition to URLs that normally do so. Returning false from this 39*6777b538SAndroid Build Coastguard Worker // method on a URL that would already be treated as secure by default, e.g. an 40*6777b538SAndroid Build Coastguard Worker // https:// one has no effect. 41*6777b538SAndroid Build Coastguard Worker virtual bool ShouldTreatUrlAsTrustworthy(const GURL& url) const; 42*6777b538SAndroid Build Coastguard Worker 43*6777b538SAndroid Build Coastguard Worker // Gets the access semantics to apply to |cookie|, based on its domain (i.e., 44*6777b538SAndroid Build Coastguard Worker // whether a policy specifies that legacy access semantics should apply). 45*6777b538SAndroid Build Coastguard Worker virtual CookieAccessSemantics GetAccessSemantics( 46*6777b538SAndroid Build Coastguard Worker const CanonicalCookie& cookie) const = 0; 47*6777b538SAndroid Build Coastguard Worker 48*6777b538SAndroid Build Coastguard Worker // Returns whether a cookie should be attached regardless of its SameSite 49*6777b538SAndroid Build Coastguard Worker // value vs the request context. 50*6777b538SAndroid Build Coastguard Worker virtual bool ShouldIgnoreSameSiteRestrictions( 51*6777b538SAndroid Build Coastguard Worker const GURL& url, 52*6777b538SAndroid Build Coastguard Worker const SiteForCookies& site_for_cookies) const = 0; 53*6777b538SAndroid Build Coastguard Worker 54*6777b538SAndroid Build Coastguard Worker // Calls `callback` with First-Party Sets metadata about `site` and 55*6777b538SAndroid Build Coastguard Worker // `top_frame_site`, and cache filter info for `site`. Cache filter info is 56*6777b538SAndroid Build Coastguard Worker // used to determine if the existing HTTP cache entries for `site` are allowed 57*6777b538SAndroid Build Coastguard Worker // to be accessed. 58*6777b538SAndroid Build Coastguard Worker // 59*6777b538SAndroid Build Coastguard Worker // This may return a result synchronously, or asynchronously invoke `callback` 60*6777b538SAndroid Build Coastguard Worker // with the result. The callback will be invoked iff the return value is 61*6777b538SAndroid Build Coastguard Worker // nullopt; i.e. a result will be provided via return value or callback, but 62*6777b538SAndroid Build Coastguard Worker // not both, and not neither. 63*6777b538SAndroid Build Coastguard Worker [[nodiscard]] virtual std::optional< 64*6777b538SAndroid Build Coastguard Worker std::pair<FirstPartySetMetadata, FirstPartySetsCacheFilter::MatchInfo>> 65*6777b538SAndroid Build Coastguard Worker ComputeFirstPartySetMetadataMaybeAsync( 66*6777b538SAndroid Build Coastguard Worker const net::SchemefulSite& site, 67*6777b538SAndroid Build Coastguard Worker const net::SchemefulSite* top_frame_site, 68*6777b538SAndroid Build Coastguard Worker base::OnceCallback<void(FirstPartySetMetadata, 69*6777b538SAndroid Build Coastguard Worker FirstPartySetsCacheFilter::MatchInfo)> callback) 70*6777b538SAndroid Build Coastguard Worker const = 0; 71*6777b538SAndroid Build Coastguard Worker 72*6777b538SAndroid Build Coastguard Worker // Returns the entries of a set of sites if the sites are in non-trivial sets. 73*6777b538SAndroid Build Coastguard Worker // If a given site is not in a non-trivial set, the output does not contain a 74*6777b538SAndroid Build Coastguard Worker // corresponding entry. 75*6777b538SAndroid Build Coastguard Worker // 76*6777b538SAndroid Build Coastguard Worker // This may return a result synchronously, or asynchronously invoke `callback` 77*6777b538SAndroid Build Coastguard Worker // with the result. The callback will be invoked iff the return value is 78*6777b538SAndroid Build Coastguard Worker // nullopt; i.e. a result will be provided via return value or callback, but 79*6777b538SAndroid Build Coastguard Worker // not both, and not neither. 80*6777b538SAndroid Build Coastguard Worker [[nodiscard]] virtual std::optional< 81*6777b538SAndroid Build Coastguard Worker base::flat_map<net::SchemefulSite, net::FirstPartySetEntry>> 82*6777b538SAndroid Build Coastguard Worker FindFirstPartySetEntries( 83*6777b538SAndroid Build Coastguard Worker const base::flat_set<net::SchemefulSite>& sites, 84*6777b538SAndroid Build Coastguard Worker base::OnceCallback< 85*6777b538SAndroid Build Coastguard Worker void(base::flat_map<net::SchemefulSite, net::FirstPartySetEntry>)> 86*6777b538SAndroid Build Coastguard Worker callback) const = 0; 87*6777b538SAndroid Build Coastguard Worker }; 88*6777b538SAndroid Build Coastguard Worker 89*6777b538SAndroid Build Coastguard Worker } // namespace net 90*6777b538SAndroid Build Coastguard Worker 91*6777b538SAndroid Build Coastguard Worker #endif // NET_COOKIES_COOKIE_ACCESS_DELEGATE_H_ 92