15821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Copyright (c) 2012 The Chromium Authors. All rights reserved. 25821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Use of this source code is governed by a BSD-style license that can be 35821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// found in the LICENSE file. 45821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 55821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#ifndef ANDROID_WEBVIEW_BROWSER_AW_COOKIE_ACCESS_POLICY_H_ 65821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#define ANDROID_WEBVIEW_BROWSER_AW_COOKIE_ACCESS_POLICY_H_ 75821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 85821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/basictypes.h" 95821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/lazy_instance.h" 105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/synchronization/lock.h" 115c02ac1a9c1b504631c0a3d2b6e737b5d738bae1Bo Liu#include "net/base/static_cookie_policy.h" 125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "net/cookies/canonical_cookie.h" 135c02ac1a9c1b504631c0a3d2b6e737b5d738bae1Bo Liu#include "net/url_request/url_request.h" 145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace content { 165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)class ResourceContext; 175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace net { 205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)class CookieOptions; 215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)class GURL; 245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace android_webview { 265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Manages the cookie access (both setting and getting) policy for WebView. 28cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)// Currently we don't distinguish between sources (i.e. network vs. JavaScript) 29cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)// or between reading vs. writing cookies. 305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)class AwCookieAccessPolicy { 315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) public: 325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) static AwCookieAccessPolicy* GetInstance(); 335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 34cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) // Can we read/write any cookies? 35cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) bool GetShouldAcceptCookies(); 36cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) void SetShouldAcceptCookies(bool allow); 375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 38cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) // Can we read/write third party cookies? 39cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) bool GetShouldAcceptThirdPartyCookies(int render_process_id, 40cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) int render_frame_id); 41cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) bool GetShouldAcceptThirdPartyCookies(const net::URLRequest& request); 425c02ac1a9c1b504631c0a3d2b6e737b5d738bae1Bo Liu 435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // These are the functions called when operating over cookies from the 445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // network. See NetworkDelegate for further descriptions. 455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) bool OnCanGetCookies(const net::URLRequest& request, 465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const net::CookieList& cookie_list); 475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) bool OnCanSetCookie(const net::URLRequest& request, 485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const std::string& cookie_line, 495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CookieOptions* options); 505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // These are the functions called when operating over cookies from the 525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // renderer. See ContentBrowserClient for further descriptions. 535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) bool AllowGetCookie(const GURL& url, 545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const GURL& first_party, 555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const net::CookieList& cookie_list, 565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) content::ResourceContext* context, 575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) int render_process_id, 585d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) int render_frame_id); 595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) bool AllowSetCookie(const GURL& url, 605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const GURL& first_party, 615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const std::string& cookie_line, 625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) content::ResourceContext* context, 635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) int render_process_id, 645d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) int render_frame_id, 655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CookieOptions* options); 665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) private: 685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) friend struct base::DefaultLazyInstanceTraits<AwCookieAccessPolicy>; 695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) AwCookieAccessPolicy(); 715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) ~AwCookieAccessPolicy(); 72cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) bool accept_cookies_; 735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::Lock lock_; 745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 75cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) DISALLOW_COPY_AND_ASSIGN(AwCookieAccessPolicy); 76cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)}; 775c02ac1a9c1b504631c0a3d2b6e737b5d738bae1Bo Liu 78cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)class AwStaticCookiePolicy { 79cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) public: 80cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) AwStaticCookiePolicy(bool allow_global_access, 81cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) bool allow_third_party_access); 825c02ac1a9c1b504631c0a3d2b6e737b5d738bae1Bo Liu 83cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) bool accept_cookies() const { 84cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) return accept_cookies_; 85cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) } 86cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) 87cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) bool accept_third_party_cookies() const { 88cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) return accept_third_party_cookies_; 89cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) } 90cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) 91cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) bool AllowGet(const GURL& url, const GURL& first_party) const; 92cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) bool AllowSet(const GURL& url, const GURL& first_party) const; 93cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) 94cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) private: 95cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) const bool accept_cookies_; 96cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) const bool accept_third_party_cookies_; 97cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) 98cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) // We have two bits of state but only three different cases: 99cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) // If !ShouldAcceptCookies 100cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) // then reject all cookies. 101cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) // If ShouldAcceptCookies and !ShouldAcceptThirdPartyCookies 102cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) // then reject third party. 103cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) // If ShouldAcceptCookies and ShouldAcceptThirdPartyCookies 104cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) // then allow all cookies. 105116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch net::StaticCookiePolicy::Type GetPolicy(const GURL& url) const; 106cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) 107cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) DISALLOW_COPY_AND_ASSIGN(AwStaticCookiePolicy); 1085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}; 1095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} // namespace android_webview 1115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#endif // ANDROID_WEBVIEW_BROWSER_AW_COOKIE_ACCESS_POLICY_H_ 113