xref: /aosp_15_r20/external/cronet/net/cookies/cookie_access_delegate.h (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
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