xref: /aosp_15_r20/external/cronet/net/cookies/cookie_options.h (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
1*6777b538SAndroid Build Coastguard Worker // Copyright 2012 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 // Brought to you by number 42.
6*6777b538SAndroid Build Coastguard Worker 
7*6777b538SAndroid Build Coastguard Worker #ifndef NET_COOKIES_COOKIE_OPTIONS_H_
8*6777b538SAndroid Build Coastguard Worker #define NET_COOKIES_COOKIE_OPTIONS_H_
9*6777b538SAndroid Build Coastguard Worker 
10*6777b538SAndroid Build Coastguard Worker #include <ostream>
11*6777b538SAndroid Build Coastguard Worker #include <string>
12*6777b538SAndroid Build Coastguard Worker 
13*6777b538SAndroid Build Coastguard Worker #include "base/check_op.h"
14*6777b538SAndroid Build Coastguard Worker #include "net/base/net_export.h"
15*6777b538SAndroid Build Coastguard Worker 
16*6777b538SAndroid Build Coastguard Worker namespace net {
17*6777b538SAndroid Build Coastguard Worker 
18*6777b538SAndroid Build Coastguard Worker class NET_EXPORT CookieOptions {
19*6777b538SAndroid Build Coastguard Worker  public:
20*6777b538SAndroid Build Coastguard Worker 
21*6777b538SAndroid Build Coastguard Worker   // Relation between the cookie and the navigational environment.
22*6777b538SAndroid Build Coastguard Worker   class NET_EXPORT SameSiteCookieContext {
23*6777b538SAndroid Build Coastguard Worker    public:
24*6777b538SAndroid Build Coastguard Worker     // CROSS_SITE to SAME_SITE_STRICT are ordered from least to most trusted
25*6777b538SAndroid Build Coastguard Worker     // environment. Don't renumber, used in histograms.
26*6777b538SAndroid Build Coastguard Worker     enum class ContextType {
27*6777b538SAndroid Build Coastguard Worker       CROSS_SITE = 0,
28*6777b538SAndroid Build Coastguard Worker       // Same rules as lax but the http method is unsafe.
29*6777b538SAndroid Build Coastguard Worker       SAME_SITE_LAX_METHOD_UNSAFE = 1,
30*6777b538SAndroid Build Coastguard Worker       SAME_SITE_LAX = 2,
31*6777b538SAndroid Build Coastguard Worker       SAME_SITE_STRICT = 3,
32*6777b538SAndroid Build Coastguard Worker 
33*6777b538SAndroid Build Coastguard Worker       // Keep last, used for histograms.
34*6777b538SAndroid Build Coastguard Worker       COUNT
35*6777b538SAndroid Build Coastguard Worker     };
36*6777b538SAndroid Build Coastguard Worker 
37*6777b538SAndroid Build Coastguard Worker     // Holds metadata about the factors that went into deciding the ContextType.
38*6777b538SAndroid Build Coastguard Worker     //
39*6777b538SAndroid Build Coastguard Worker     // These values may be used for recording histograms or
40*6777b538SAndroid Build Coastguard Worker     // CookieInclusionStatus warnings, but SHOULD NOT be relied
41*6777b538SAndroid Build Coastguard Worker     // upon for cookie inclusion decisions. Use only the ContextTypes for that.
42*6777b538SAndroid Build Coastguard Worker     //
43*6777b538SAndroid Build Coastguard Worker     // When adding a field, also update CompleteEquivalenceForTesting.
44*6777b538SAndroid Build Coastguard Worker     struct NET_EXPORT ContextMetadata {
45*6777b538SAndroid Build Coastguard Worker       // Possible "downgrades" for the SameSite context type, e.g. from a more
46*6777b538SAndroid Build Coastguard Worker       // trusted context to a less trusted context, as a result of some behavior
47*6777b538SAndroid Build Coastguard Worker       // change affecting the same-site calculation.
48*6777b538SAndroid Build Coastguard Worker       enum class ContextDowngradeType {
49*6777b538SAndroid Build Coastguard Worker         // Context not downgraded.
50*6777b538SAndroid Build Coastguard Worker         kNoDowngrade,
51*6777b538SAndroid Build Coastguard Worker         // Context was originally strictly same-site, was downgraded to laxly
52*6777b538SAndroid Build Coastguard Worker         // same-site.
53*6777b538SAndroid Build Coastguard Worker         kStrictToLax,
54*6777b538SAndroid Build Coastguard Worker         // Context was originally strictly same-site, was downgraded to
55*6777b538SAndroid Build Coastguard Worker         // cross-site.
56*6777b538SAndroid Build Coastguard Worker         kStrictToCross,
57*6777b538SAndroid Build Coastguard Worker         // Context was originally laxly same-site, was downgraded to cross-site.
58*6777b538SAndroid Build Coastguard Worker         kLaxToCross,
59*6777b538SAndroid Build Coastguard Worker       };
60*6777b538SAndroid Build Coastguard Worker 
61*6777b538SAndroid Build Coastguard Worker       // These values are persisted to logs. Entries should not be renumbered
62*6777b538SAndroid Build Coastguard Worker       // and numeric values should never be reused.
63*6777b538SAndroid Build Coastguard Worker       // This enum is to help collect metrics for https://crbug.com/1221316.
64*6777b538SAndroid Build Coastguard Worker       // Specifically it's to help indicate how many cookies are accessed with a
65*6777b538SAndroid Build Coastguard Worker       // given redirect type in order to provide a denominator for the
66*6777b538SAndroid Build Coastguard Worker       // Cookie.CrossSiteRedirectDowngradeChangesInclusion2.* metrics.
67*6777b538SAndroid Build Coastguard Worker       // Note: for this enum the notation A->B->C means that a navigation from
68*6777b538SAndroid Build Coastguard Worker       // A to B was redirected to C. I.e.: A is the initator of the navigation
69*6777b538SAndroid Build Coastguard Worker       // and C is the final url.
70*6777b538SAndroid Build Coastguard Worker       enum class ContextRedirectTypeBug1221316 {
71*6777b538SAndroid Build Coastguard Worker         kUnset =
72*6777b538SAndroid Build Coastguard Worker             0,  // Indicates this value was unused and shouldn't be read. E.x.:
73*6777b538SAndroid Build Coastguard Worker                 // A javascript access means this value is meaningless.
74*6777b538SAndroid Build Coastguard Worker         kNoRedirect = 1,  // There weren't any redirects. E.x.: A->B, A->A
75*6777b538SAndroid Build Coastguard Worker         kCrossSiteRedirect =
76*6777b538SAndroid Build Coastguard Worker             2,  // There was a redirect but it didn't start and
77*6777b538SAndroid Build Coastguard Worker                 // end at the same site or the redirect was to a different site
78*6777b538SAndroid Build Coastguard Worker                 // than the site-for-cookies. E.x.: A->B->C or B->B->B when the
79*6777b538SAndroid Build Coastguard Worker                 // site-for-cookies is A.
80*6777b538SAndroid Build Coastguard Worker         kPartialSameSiteRedirect =
81*6777b538SAndroid Build Coastguard Worker             3,  // There was a redirect and the start and
82*6777b538SAndroid Build Coastguard Worker                 // end are the same site. E.x.: A->B->A. Only this one could
83*6777b538SAndroid Build Coastguard Worker                 // potentially set cross_site_redirect_downgrade.
84*6777b538SAndroid Build Coastguard Worker         kAllSameSiteRedirect = 4,  // There was a redirect and all urls are the
85*6777b538SAndroid Build Coastguard Worker                                    // same site. E.x.:, A->A->A
86*6777b538SAndroid Build Coastguard Worker         kMaxValue = kAllSameSiteRedirect
87*6777b538SAndroid Build Coastguard Worker       };
88*6777b538SAndroid Build Coastguard Worker 
89*6777b538SAndroid Build Coastguard Worker       // These values are persisted to logs. Entries should not be renumbered
90*6777b538SAndroid Build Coastguard Worker       // and numeric values should never be reused.
91*6777b538SAndroid Build Coastguard Worker       enum class HttpMethod {
92*6777b538SAndroid Build Coastguard Worker         // kUnset indicates this enum wasn't applicable in the context.
93*6777b538SAndroid Build Coastguard Worker         kUnset = -1,
94*6777b538SAndroid Build Coastguard Worker         // kUnknown indicates we were unable to convert the method string to
95*6777b538SAndroid Build Coastguard Worker         // this enum.
96*6777b538SAndroid Build Coastguard Worker         kUnknown = 0,
97*6777b538SAndroid Build Coastguard Worker         kGet = 1,
98*6777b538SAndroid Build Coastguard Worker         kHead = 2,
99*6777b538SAndroid Build Coastguard Worker         kPost = 3,
100*6777b538SAndroid Build Coastguard Worker         KPut = 4,
101*6777b538SAndroid Build Coastguard Worker         kDelete = 5,
102*6777b538SAndroid Build Coastguard Worker         kConnect = 6,
103*6777b538SAndroid Build Coastguard Worker         kOptions = 7,
104*6777b538SAndroid Build Coastguard Worker         kTrace = 8,
105*6777b538SAndroid Build Coastguard Worker         kPatch = 9,
106*6777b538SAndroid Build Coastguard Worker         kMaxValue = kPatch
107*6777b538SAndroid Build Coastguard Worker       };
108*6777b538SAndroid Build Coastguard Worker 
109*6777b538SAndroid Build Coastguard Worker       // Records the type of any context downgrade due to a cross-site redirect,
110*6777b538SAndroid Build Coastguard Worker       // i.e. whether the spec change in
111*6777b538SAndroid Build Coastguard Worker       // https://github.com/httpwg/http-extensions/pull/1348 changed the result
112*6777b538SAndroid Build Coastguard Worker       // of the context calculation. Note that a lax-to-cross downgrade can only
113*6777b538SAndroid Build Coastguard Worker       // happen for response cookies, because a laxly same-site context only
114*6777b538SAndroid Build Coastguard Worker       // happens for a top-level cross-site request, which cannot be downgraded
115*6777b538SAndroid Build Coastguard Worker       // due to a cross-site redirect to a non-top-level cross-site request.
116*6777b538SAndroid Build Coastguard Worker       // This only records whether the context was downgraded, not whether the
117*6777b538SAndroid Build Coastguard Worker       // cookie's inclusion result was changed.
118*6777b538SAndroid Build Coastguard Worker       ContextDowngradeType cross_site_redirect_downgrade =
119*6777b538SAndroid Build Coastguard Worker           ContextDowngradeType::kNoDowngrade;
120*6777b538SAndroid Build Coastguard Worker 
121*6777b538SAndroid Build Coastguard Worker       ContextRedirectTypeBug1221316 redirect_type_bug_1221316 =
122*6777b538SAndroid Build Coastguard Worker           ContextRedirectTypeBug1221316::kUnset;
123*6777b538SAndroid Build Coastguard Worker 
124*6777b538SAndroid Build Coastguard Worker       // Records the HTTP method of requests that result in a cross-site
125*6777b538SAndroid Build Coastguard Worker       // redirect downgrade. May be kUnset if there wasn't a downgrade or if the
126*6777b538SAndroid Build Coastguard Worker       // cookie access wasn't due to a request.
127*6777b538SAndroid Build Coastguard Worker       //
128*6777b538SAndroid Build Coastguard Worker       // Note that this field is always set when there was a context
129*6777b538SAndroid Build Coastguard Worker       // downgrade but the associated histrogram is only recorded when that
130*6777b538SAndroid Build Coastguard Worker       // context downgrade results in a change in inclusion status.
131*6777b538SAndroid Build Coastguard Worker       HttpMethod http_method_bug_1221316 = HttpMethod::kUnset;
132*6777b538SAndroid Build Coastguard Worker     };
133*6777b538SAndroid Build Coastguard Worker 
134*6777b538SAndroid Build Coastguard Worker     // The following three constructors apply default values for the metadata
135*6777b538SAndroid Build Coastguard Worker     // members.
SameSiteCookieContext()136*6777b538SAndroid Build Coastguard Worker     SameSiteCookieContext()
137*6777b538SAndroid Build Coastguard Worker         : SameSiteCookieContext(ContextType::CROSS_SITE,
138*6777b538SAndroid Build Coastguard Worker                                 ContextType::CROSS_SITE) {}
139*6777b538SAndroid Build Coastguard Worker 
SameSiteCookieContext(ContextType same_site_context)140*6777b538SAndroid Build Coastguard Worker     explicit SameSiteCookieContext(ContextType same_site_context)
141*6777b538SAndroid Build Coastguard Worker         : SameSiteCookieContext(same_site_context, same_site_context) {}
142*6777b538SAndroid Build Coastguard Worker 
SameSiteCookieContext(ContextType same_site_context,ContextType schemeful_same_site_context)143*6777b538SAndroid Build Coastguard Worker     SameSiteCookieContext(ContextType same_site_context,
144*6777b538SAndroid Build Coastguard Worker                           ContextType schemeful_same_site_context)
145*6777b538SAndroid Build Coastguard Worker         : SameSiteCookieContext(same_site_context,
146*6777b538SAndroid Build Coastguard Worker                                 schemeful_same_site_context,
147*6777b538SAndroid Build Coastguard Worker                                 ContextMetadata(),
148*6777b538SAndroid Build Coastguard Worker                                 ContextMetadata()) {}
149*6777b538SAndroid Build Coastguard Worker 
150*6777b538SAndroid Build Coastguard Worker     // Schemeful and schemeless context types are consistency-checked against
151*6777b538SAndroid Build Coastguard Worker     // each other, but the metadata is stored as-is (i.e. the values in
152*6777b538SAndroid Build Coastguard Worker     // `metadata` and `schemeful_metadata` may be logically inconsistent), as
153*6777b538SAndroid Build Coastguard Worker     // the metadata is not relied upon for correctness.
SameSiteCookieContext(ContextType same_site_context,ContextType schemeful_same_site_context,ContextMetadata metadata,ContextMetadata schemeful_metadata)154*6777b538SAndroid Build Coastguard Worker     SameSiteCookieContext(ContextType same_site_context,
155*6777b538SAndroid Build Coastguard Worker                           ContextType schemeful_same_site_context,
156*6777b538SAndroid Build Coastguard Worker                           ContextMetadata metadata,
157*6777b538SAndroid Build Coastguard Worker                           ContextMetadata schemeful_metadata)
158*6777b538SAndroid Build Coastguard Worker         : context_(same_site_context),
159*6777b538SAndroid Build Coastguard Worker           schemeful_context_(schemeful_same_site_context),
160*6777b538SAndroid Build Coastguard Worker           metadata_(metadata),
161*6777b538SAndroid Build Coastguard Worker           schemeful_metadata_(schemeful_metadata) {
162*6777b538SAndroid Build Coastguard Worker       DCHECK_LE(schemeful_context_, context_);
163*6777b538SAndroid Build Coastguard Worker     }
164*6777b538SAndroid Build Coastguard Worker 
165*6777b538SAndroid Build Coastguard Worker     // Convenience method which returns a SameSiteCookieContext with the most
166*6777b538SAndroid Build Coastguard Worker     // inclusive contexts. This allows access to all SameSite cookies.
167*6777b538SAndroid Build Coastguard Worker     static SameSiteCookieContext MakeInclusive();
168*6777b538SAndroid Build Coastguard Worker 
169*6777b538SAndroid Build Coastguard Worker     // Convenience method which returns a SameSiteCookieContext with the most
170*6777b538SAndroid Build Coastguard Worker     // inclusive contexts for set. This allows setting all SameSite cookies.
171*6777b538SAndroid Build Coastguard Worker     static SameSiteCookieContext MakeInclusiveForSet();
172*6777b538SAndroid Build Coastguard Worker 
173*6777b538SAndroid Build Coastguard Worker     // Returns the context for determining SameSite cookie inclusion.
174*6777b538SAndroid Build Coastguard Worker     ContextType GetContextForCookieInclusion() const;
175*6777b538SAndroid Build Coastguard Worker 
176*6777b538SAndroid Build Coastguard Worker     // Returns the metadata describing how this context was calculated, under
177*6777b538SAndroid Build Coastguard Worker     // the currently applicable schemeful/schemeless mode.
178*6777b538SAndroid Build Coastguard Worker     // TODO(chlily): Should take the CookieAccessSemantics as well, to
179*6777b538SAndroid Build Coastguard Worker     // accurately account for the context actually used for a given cookie.
180*6777b538SAndroid Build Coastguard Worker     const ContextMetadata& GetMetadataForCurrentSchemefulMode() const;
181*6777b538SAndroid Build Coastguard Worker 
182*6777b538SAndroid Build Coastguard Worker     // If you're just trying to determine if a cookie is accessible you likely
183*6777b538SAndroid Build Coastguard Worker     // want to use GetContextForCookieInclusion() which will return the correct
184*6777b538SAndroid Build Coastguard Worker     // context regardless the status of same-site features.
context()185*6777b538SAndroid Build Coastguard Worker     ContextType context() const { return context_; }
schemeful_context()186*6777b538SAndroid Build Coastguard Worker     ContextType schemeful_context() const { return schemeful_context_; }
187*6777b538SAndroid Build Coastguard Worker 
188*6777b538SAndroid Build Coastguard Worker     // You probably want to use GetMetadataForCurrentSchemefulMode() instead of
189*6777b538SAndroid Build Coastguard Worker     // these getters, since that takes into account the applicable schemeful
190*6777b538SAndroid Build Coastguard Worker     // mode.
metadata()191*6777b538SAndroid Build Coastguard Worker     const ContextMetadata& metadata() const { return metadata_; }
metadata()192*6777b538SAndroid Build Coastguard Worker     ContextMetadata& metadata() { return metadata_; }
schemeful_metadata()193*6777b538SAndroid Build Coastguard Worker     const ContextMetadata& schemeful_metadata() const {
194*6777b538SAndroid Build Coastguard Worker       return schemeful_metadata_;
195*6777b538SAndroid Build Coastguard Worker     }
schemeful_metadata()196*6777b538SAndroid Build Coastguard Worker     ContextMetadata& schemeful_metadata() { return schemeful_metadata_; }
197*6777b538SAndroid Build Coastguard Worker 
198*6777b538SAndroid Build Coastguard Worker     // Sets context types. Does not check for consistency between context and
199*6777b538SAndroid Build Coastguard Worker     // schemeful context. Does not touch the metadata.
200*6777b538SAndroid Build Coastguard Worker     void SetContextTypesForTesting(ContextType context_type,
201*6777b538SAndroid Build Coastguard Worker                                    ContextType schemeful_context_type);
202*6777b538SAndroid Build Coastguard Worker 
203*6777b538SAndroid Build Coastguard Worker     // Returns whether the context types and all fields of the metadata structs
204*6777b538SAndroid Build Coastguard Worker     // are the same.
205*6777b538SAndroid Build Coastguard Worker     bool CompleteEquivalenceForTesting(
206*6777b538SAndroid Build Coastguard Worker         const SameSiteCookieContext& other) const;
207*6777b538SAndroid Build Coastguard Worker 
208*6777b538SAndroid Build Coastguard Worker     // Equality operators disregard any metadata! (Only the context types are
209*6777b538SAndroid Build Coastguard Worker     // compared, not how they were computed.)
210*6777b538SAndroid Build Coastguard Worker     NET_EXPORT friend bool operator==(
211*6777b538SAndroid Build Coastguard Worker         const CookieOptions::SameSiteCookieContext& lhs,
212*6777b538SAndroid Build Coastguard Worker         const CookieOptions::SameSiteCookieContext& rhs);
213*6777b538SAndroid Build Coastguard Worker     NET_EXPORT friend bool operator!=(
214*6777b538SAndroid Build Coastguard Worker         const CookieOptions::SameSiteCookieContext& lhs,
215*6777b538SAndroid Build Coastguard Worker         const CookieOptions::SameSiteCookieContext& rhs);
216*6777b538SAndroid Build Coastguard Worker 
217*6777b538SAndroid Build Coastguard Worker    private:
218*6777b538SAndroid Build Coastguard Worker     ContextType context_;
219*6777b538SAndroid Build Coastguard Worker     ContextType schemeful_context_;
220*6777b538SAndroid Build Coastguard Worker 
221*6777b538SAndroid Build Coastguard Worker     ContextMetadata metadata_;
222*6777b538SAndroid Build Coastguard Worker     ContextMetadata schemeful_metadata_;
223*6777b538SAndroid Build Coastguard Worker   };
224*6777b538SAndroid Build Coastguard Worker 
225*6777b538SAndroid Build Coastguard Worker   // Creates a CookieOptions object which:
226*6777b538SAndroid Build Coastguard Worker   //
227*6777b538SAndroid Build Coastguard Worker   // * Excludes HttpOnly cookies
228*6777b538SAndroid Build Coastguard Worker   // * Excludes SameSite cookies
229*6777b538SAndroid Build Coastguard Worker   // * Updates last-accessed time.
230*6777b538SAndroid Build Coastguard Worker   // * Does not report excluded cookies in APIs that can do so.
231*6777b538SAndroid Build Coastguard Worker   //
232*6777b538SAndroid Build Coastguard Worker   // These settings can be altered by calling:
233*6777b538SAndroid Build Coastguard Worker   //
234*6777b538SAndroid Build Coastguard Worker   // * |set_{include,exclude}_httponly()|
235*6777b538SAndroid Build Coastguard Worker   // * |set_same_site_cookie_context()|
236*6777b538SAndroid Build Coastguard Worker   // * |set_do_not_update_access_time()|
237*6777b538SAndroid Build Coastguard Worker   CookieOptions();
238*6777b538SAndroid Build Coastguard Worker   CookieOptions(const CookieOptions& other);
239*6777b538SAndroid Build Coastguard Worker   CookieOptions(CookieOptions&& other);
240*6777b538SAndroid Build Coastguard Worker   ~CookieOptions();
241*6777b538SAndroid Build Coastguard Worker 
242*6777b538SAndroid Build Coastguard Worker   CookieOptions& operator=(const CookieOptions&);
243*6777b538SAndroid Build Coastguard Worker   CookieOptions& operator=(CookieOptions&&);
244*6777b538SAndroid Build Coastguard Worker 
set_exclude_httponly()245*6777b538SAndroid Build Coastguard Worker   void set_exclude_httponly() { exclude_httponly_ = true; }
set_include_httponly()246*6777b538SAndroid Build Coastguard Worker   void set_include_httponly() { exclude_httponly_ = false; }
exclude_httponly()247*6777b538SAndroid Build Coastguard Worker   bool exclude_httponly() const { return exclude_httponly_; }
248*6777b538SAndroid Build Coastguard Worker 
249*6777b538SAndroid Build Coastguard Worker   // How trusted is the current browser environment when it comes to accessing
250*6777b538SAndroid Build Coastguard Worker   // SameSite cookies. Default is not trusted, e.g. CROSS_SITE.
set_same_site_cookie_context(const SameSiteCookieContext & context)251*6777b538SAndroid Build Coastguard Worker   void set_same_site_cookie_context(const SameSiteCookieContext& context) {
252*6777b538SAndroid Build Coastguard Worker     same_site_cookie_context_ = context;
253*6777b538SAndroid Build Coastguard Worker   }
254*6777b538SAndroid Build Coastguard Worker 
same_site_cookie_context()255*6777b538SAndroid Build Coastguard Worker   const SameSiteCookieContext& same_site_cookie_context() const {
256*6777b538SAndroid Build Coastguard Worker     return same_site_cookie_context_;
257*6777b538SAndroid Build Coastguard Worker   }
258*6777b538SAndroid Build Coastguard Worker 
set_update_access_time()259*6777b538SAndroid Build Coastguard Worker   void set_update_access_time() { update_access_time_ = true; }
set_do_not_update_access_time()260*6777b538SAndroid Build Coastguard Worker   void set_do_not_update_access_time() { update_access_time_ = false; }
update_access_time()261*6777b538SAndroid Build Coastguard Worker   bool update_access_time() const { return update_access_time_; }
262*6777b538SAndroid Build Coastguard Worker 
set_return_excluded_cookies()263*6777b538SAndroid Build Coastguard Worker   void set_return_excluded_cookies() { return_excluded_cookies_ = true; }
unset_return_excluded_cookies()264*6777b538SAndroid Build Coastguard Worker   void unset_return_excluded_cookies() { return_excluded_cookies_ = false; }
return_excluded_cookies()265*6777b538SAndroid Build Coastguard Worker   bool return_excluded_cookies() const { return return_excluded_cookies_; }
266*6777b538SAndroid Build Coastguard Worker 
267*6777b538SAndroid Build Coastguard Worker   // Convenience method for where you need a CookieOptions that will
268*6777b538SAndroid Build Coastguard Worker   // work for getting/setting all types of cookies, including HttpOnly and
269*6777b538SAndroid Build Coastguard Worker   // SameSite cookies. Also specifies not to update the access time, because
270*6777b538SAndroid Build Coastguard Worker   // usually this is done to get all the cookies to check that they are correct,
271*6777b538SAndroid Build Coastguard Worker   // including the creation time. This basically makes a CookieOptions that is
272*6777b538SAndroid Build Coastguard Worker   // the opposite of the default CookieOptions.
273*6777b538SAndroid Build Coastguard Worker   static CookieOptions MakeAllInclusive();
274*6777b538SAndroid Build Coastguard Worker 
275*6777b538SAndroid Build Coastguard Worker  private:
276*6777b538SAndroid Build Coastguard Worker   // Keep default values in sync with
277*6777b538SAndroid Build Coastguard Worker   // content/public/common/cookie_manager.mojom.
278*6777b538SAndroid Build Coastguard Worker   bool exclude_httponly_ = true;
279*6777b538SAndroid Build Coastguard Worker   SameSiteCookieContext same_site_cookie_context_;
280*6777b538SAndroid Build Coastguard Worker   bool update_access_time_ = true;
281*6777b538SAndroid Build Coastguard Worker   bool return_excluded_cookies_ = false;
282*6777b538SAndroid Build Coastguard Worker };
283*6777b538SAndroid Build Coastguard Worker 
284*6777b538SAndroid Build Coastguard Worker NET_EXPORT bool operator==(
285*6777b538SAndroid Build Coastguard Worker     const CookieOptions::SameSiteCookieContext::ContextMetadata& lhs,
286*6777b538SAndroid Build Coastguard Worker     const CookieOptions::SameSiteCookieContext::ContextMetadata& rhs);
287*6777b538SAndroid Build Coastguard Worker NET_EXPORT bool operator!=(
288*6777b538SAndroid Build Coastguard Worker     const CookieOptions::SameSiteCookieContext::ContextMetadata& lhs,
289*6777b538SAndroid Build Coastguard Worker     const CookieOptions::SameSiteCookieContext::ContextMetadata& rhs);
290*6777b538SAndroid Build Coastguard Worker 
291*6777b538SAndroid Build Coastguard Worker // Allows gtest to print more helpful error messages instead of printing hex.
292*6777b538SAndroid Build Coastguard Worker // (No need to null-check `os` because we can assume gtest will properly pass a
293*6777b538SAndroid Build Coastguard Worker // non-null pointer, and it is dereferenced immediately anyway.)
PrintTo(CookieOptions::SameSiteCookieContext::ContextType ct,std::ostream * os)294*6777b538SAndroid Build Coastguard Worker inline void PrintTo(CookieOptions::SameSiteCookieContext::ContextType ct,
295*6777b538SAndroid Build Coastguard Worker                     std::ostream* os) {
296*6777b538SAndroid Build Coastguard Worker   *os << static_cast<int>(ct);
297*6777b538SAndroid Build Coastguard Worker }
298*6777b538SAndroid Build Coastguard Worker 
PrintTo(const CookieOptions::SameSiteCookieContext::ContextMetadata & m,std::ostream * os)299*6777b538SAndroid Build Coastguard Worker inline void PrintTo(
300*6777b538SAndroid Build Coastguard Worker     const CookieOptions::SameSiteCookieContext::ContextMetadata& m,
301*6777b538SAndroid Build Coastguard Worker     std::ostream* os) {
302*6777b538SAndroid Build Coastguard Worker   *os << "{";
303*6777b538SAndroid Build Coastguard Worker   *os << " cross_site_redirect_downgrade: "
304*6777b538SAndroid Build Coastguard Worker       << static_cast<int>(m.cross_site_redirect_downgrade);
305*6777b538SAndroid Build Coastguard Worker   *os << ", redirect_type_bug_1221316: "
306*6777b538SAndroid Build Coastguard Worker       << static_cast<int>(m.redirect_type_bug_1221316);
307*6777b538SAndroid Build Coastguard Worker   *os << ", http_method_bug_1221316: "
308*6777b538SAndroid Build Coastguard Worker       << static_cast<int>(m.http_method_bug_1221316);
309*6777b538SAndroid Build Coastguard Worker   *os << " }";
310*6777b538SAndroid Build Coastguard Worker }
311*6777b538SAndroid Build Coastguard Worker 
PrintTo(const CookieOptions::SameSiteCookieContext & sscc,std::ostream * os)312*6777b538SAndroid Build Coastguard Worker inline void PrintTo(const CookieOptions::SameSiteCookieContext& sscc,
313*6777b538SAndroid Build Coastguard Worker                     std::ostream* os) {
314*6777b538SAndroid Build Coastguard Worker   *os << "{ context: ";
315*6777b538SAndroid Build Coastguard Worker   PrintTo(sscc.context(), os);
316*6777b538SAndroid Build Coastguard Worker   *os << ", schemeful_context: ";
317*6777b538SAndroid Build Coastguard Worker   PrintTo(sscc.schemeful_context(), os);
318*6777b538SAndroid Build Coastguard Worker   *os << ", metadata: ";
319*6777b538SAndroid Build Coastguard Worker   PrintTo(sscc.metadata(), os);
320*6777b538SAndroid Build Coastguard Worker   *os << ", schemeful_metadata: ";
321*6777b538SAndroid Build Coastguard Worker   PrintTo(sscc.schemeful_metadata(), os);
322*6777b538SAndroid Build Coastguard Worker   *os << " }";
323*6777b538SAndroid Build Coastguard Worker }
324*6777b538SAndroid Build Coastguard Worker 
325*6777b538SAndroid Build Coastguard Worker }  // namespace net
326*6777b538SAndroid Build Coastguard Worker 
327*6777b538SAndroid Build Coastguard Worker #endif  // NET_COOKIES_COOKIE_OPTIONS_H_
328