diff options
author | amit@chromium.org <amit@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-07-28 13:28:11 +0000 |
---|---|---|
committer | amit@chromium.org <amit@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-07-28 13:28:11 +0000 |
commit | 5f450e5c6fc98a762cebb38cd080731bedd61ae3 (patch) | |
tree | de1e6a257709c220222a6ab9defac23aade6e45c /net/base/cookie_monster.h | |
parent | 60147f3b071444f0abfb320e62a0c9f2b666d443 (diff) | |
download | chromium_src-5f450e5c6fc98a762cebb38cd080731bedd61ae3.zip chromium_src-5f450e5c6fc98a762cebb38cd080731bedd61ae3.tar.gz chromium_src-5f450e5c6fc98a762cebb38cd080731bedd61ae3.tar.bz2 |
Navigation and cookies for Automation
Give Automation better visibility and control over navigations.
Also, make it possible for automation to implement a dummy cookie
store to go with dummy request serving over automation.
BUG=none
TEST=none
Review URL: http://codereview.chromium.org/159189
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@21836 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'net/base/cookie_monster.h')
-rw-r--r-- | net/base/cookie_monster.h | 68 |
1 files changed, 27 insertions, 41 deletions
diff --git a/net/base/cookie_monster.h b/net/base/cookie_monster.h index 24db893..638a8ed 100644 --- a/net/base/cookie_monster.h +++ b/net/base/cookie_monster.h @@ -15,6 +15,7 @@ #include "base/basictypes.h" #include "base/lock.h" #include "base/time.h" +#include "net/base/cookie_store.h" class GURL; @@ -30,7 +31,7 @@ namespace net { // // TODO(deanm) Implement CookieMonster, the cookie database. // - Verify that our domain enforcement and non-dotted handling is correct -class CookieMonster { +class CookieMonster : public CookieStore { public: class ParsedCookie; class CanonicalCookie; @@ -49,18 +50,6 @@ class CookieMonster { typedef std::pair<std::string, CanonicalCookie> CookieListPair; typedef std::vector<CookieListPair> CookieList; - class CookieOptions { - public: - // Default is to exclude httponly, which means: - // - reading operations will not return httponly cookies. - // - writing operations will not write httponly cookies. - CookieOptions() : exclude_httponly_(true) {} - void set_exclude_httponly() { exclude_httponly_ = true; } - void set_include_httponly() { exclude_httponly_ = false; } - bool exclude_httponly() const { return exclude_httponly_; } - private: - bool exclude_httponly_; - }; CookieMonster(); @@ -85,35 +74,32 @@ class CookieMonster { // Parse the string with the cookie time (very forgivingly). static base::Time ParseCookieTime(const std::string& time_string); - // Set a single cookie. Expects a cookie line, like "a=1; domain=b.com". - bool SetCookie(const GURL& url, const std::string& cookie_line); - bool SetCookieWithOptions(const GURL& url, - const std::string& cookie_line, - const CookieOptions& options); - // Sets a single cookie with a specific creation date. To set a cookie with - // a creation date of Now() use SetCookie() instead (it calls this function - // internally). - bool SetCookieWithCreationTime(const GURL& url, - const std::string& cookie_line, - const base::Time& creation_time); - bool SetCookieWithCreationTimeWithOptions( - const GURL& url, - const std::string& cookie_line, - const base::Time& creation_time, - const CookieOptions& options); - // Set a vector of response cookie values for the same URL. - void SetCookies(const GURL& url, const std::vector<std::string>& cookies); - void SetCookiesWithOptions(const GURL& url, - const std::vector<std::string>& cookies, - const CookieOptions& options); - - // TODO what if the total size of all the cookies >4k, can we have a header - // that big or do we need multiple Cookie: headers? - // Simple interface, get a cookie string "a=b; c=d" for the given URL. - // It will _not_ return httponly cookies, see CookieOptions. - std::string GetCookies(const GURL& url); - std::string GetCookiesWithOptions(const GURL& url, + // CookieStore implementation. + virtual bool SetCookie(const GURL& url, const std::string& cookie_line); + virtual bool SetCookieWithOptions(const GURL& url, + const std::string& cookie_line, const CookieOptions& options); + virtual bool SetCookieWithCreationTime(const GURL& url, + const std::string& cookie_line, + const base::Time& creation_time); + virtual bool SetCookieWithCreationTimeWithOptions( + const GURL& url, + const std::string& cookie_line, + const base::Time& creation_time, + const CookieOptions& options); + virtual void SetCookies(const GURL& url, + const std::vector<std::string>& cookies); + virtual void SetCookiesWithOptions(const GURL& url, + const std::vector<std::string>& cookies, + const CookieOptions& options); + virtual std::string GetCookies(const GURL& url); + virtual std::string GetCookiesWithOptions(const GURL& url, + const CookieOptions& options); + + virtual CookieMonster* GetCookieMonster() { + return this; + } + // Returns all the cookies, for use in management UI, etc. This does not mark // the cookies as having been accessed. CookieList GetAllCookies(); |