blob: 257de779cfb1f470a77c25a4187b0fb05abaa191 [file] [log] [blame]
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef ANDROID_WEBVIEW_BROWSER_AW_COOKIE_ACCESS_POLICY_H_
#define ANDROID_WEBVIEW_BROWSER_AW_COOKIE_ACCESS_POLICY_H_
#include "base/lazy_instance.h"
#include "base/macros.h"
#include "base/synchronization/lock.h"
#include "net/base/static_cookie_policy.h"
#include "net/cookies/canonical_cookie.h"
#include "net/url_request/url_request.h"
namespace content {
class ResourceContext;
}
class GURL;
namespace android_webview {
// Manages the cookie access (both setting and getting) policy for WebView.
// Currently we don't distinguish between sources (i.e. network vs. JavaScript)
// or between reading vs. writing cookies.
class AwCookieAccessPolicy {
public:
static AwCookieAccessPolicy* GetInstance();
// Can we read/write any cookies?
bool GetShouldAcceptCookies();
void SetShouldAcceptCookies(bool allow);
// Can we read/write third party cookies?
// |render_process_id| and |render_frame_id| must be valid.
// Navigation requests are not associated with a renderer process. In this
// case, |frame_tree_node_id| must be valid instead.
bool GetShouldAcceptThirdPartyCookies(int render_process_id,
int render_frame_id,
int frame_tree_node_id);
bool GetShouldAcceptThirdPartyCookies(const net::URLRequest& request);
// These are the functions called when operating over cookies from the
// network. See NetworkDelegate for further descriptions.
bool OnCanGetCookies(const net::URLRequest& request,
const net::CookieList& cookie_list);
bool OnCanSetCookie(const net::URLRequest& request,
const net::CanonicalCookie& cookie,
net::CookieOptions* options);
// These are the functions called when operating over cookies from the
// renderer. See ContentBrowserClient for further descriptions.
bool AllowGetCookie(const GURL& url,
const GURL& first_party,
const net::CookieList& cookie_list,
content::ResourceContext* context,
int render_process_id,
int render_frame_id);
bool AllowSetCookie(const GURL& url,
const GURL& first_party,
const net::CanonicalCookie& cookie,
content::ResourceContext* context,
int render_process_id,
int render_frame_id);
private:
friend struct base::LazyInstanceTraitsBase<AwCookieAccessPolicy>;
AwCookieAccessPolicy();
~AwCookieAccessPolicy();
bool accept_cookies_;
base::Lock lock_;
DISALLOW_COPY_AND_ASSIGN(AwCookieAccessPolicy);
};
class AwStaticCookiePolicy {
public:
AwStaticCookiePolicy(bool allow_global_access,
bool allow_third_party_access);
bool accept_cookies() const {
return accept_cookies_;
}
bool accept_third_party_cookies() const {
return accept_third_party_cookies_;
}
bool AllowGet(const GURL& url, const GURL& first_party) const;
bool AllowSet(const GURL& url, const GURL& first_party) const;
private:
const bool accept_cookies_;
const bool accept_third_party_cookies_;
// We have two bits of state but only three different cases:
// If !ShouldAcceptCookies
// then reject all cookies.
// If ShouldAcceptCookies and !ShouldAcceptThirdPartyCookies
// then reject third party.
// If ShouldAcceptCookies and ShouldAcceptThirdPartyCookies
// then allow all cookies.
net::StaticCookiePolicy::Type GetPolicy(const GURL& url) const;
DISALLOW_COPY_AND_ASSIGN(AwStaticCookiePolicy);
};
} // namespace android_webview
#endif // ANDROID_WEBVIEW_BROWSER_AW_COOKIE_ACCESS_POLICY_H_