Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(206)

Side by Side Diff: chrome/browser/extensions/api/cookies/cookies_helpers.h

Issue 10702088: Refactor chrome.cookies API to use JSON schema compiler. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Sync Created 8 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 // Defines common functionality used by the implementation of the Chrome 5 // Defines common functionality used by the implementation of the Chrome
6 // Extensions Cookies API implemented in 6 // Extensions Cookies API implemented in
7 // chrome/browser/extensions/api/cookies/cookies_api.cc. This separate interface 7 // chrome/browser/extensions/api/cookies/cookies_api.cc. This separate interface
8 // exposes pieces of the API implementation mainly for unit testing purposes. 8 // exposes pieces of the API implementation mainly for unit testing purposes.
9 9
10 #ifndef CHROME_BROWSER_EXTENSIONS_API_COOKIES_COOKIES_HELPERS_H_ 10 #ifndef CHROME_BROWSER_EXTENSIONS_API_COOKIES_COOKIES_HELPERS_H_
11 #define CHROME_BROWSER_EXTENSIONS_API_COOKIES_COOKIES_HELPERS_H_ 11 #define CHROME_BROWSER_EXTENSIONS_API_COOKIES_COOKIES_HELPERS_H_
12 12
13 #include <string> 13 #include <string>
14 #include <vector>
14 15
16 #include "base/memory/linked_ptr.h"
17 #include "base/memory/scoped_ptr.h"
18 #include "chrome/common/extensions/api/cookies.h"
15 #include "net/cookies/cookie_monster.h" 19 #include "net/cookies/cookie_monster.h"
20 #include "net/cookies/canonical_cookie.h"
16 21
17 class Browser; 22 class Browser;
18 class Profile; 23 class Profile;
19 24
20 namespace base { 25 namespace base {
21 class DictionaryValue; 26 class DictionaryValue;
22 class ListValue; 27 class ListValue;
23 } 28 }
24 29
25 namespace net { 30 namespace net {
26 class CanonicalCookie; 31 class CanonicalCookie;
27 } 32 }
28 33
29 namespace extensions { 34 namespace extensions {
30 35
31 class Extension; 36 class Extension;
32 37
33 namespace cookies_helpers { 38 namespace cookies_helpers {
34 39
40 typedef std::vector<linked_ptr<extensions::api::cookies::Cookie> >
41 LinkedCookieVec;
42
35 // Returns either the original profile or the incognito profile, based on the 43 // Returns either the original profile or the incognito profile, based on the
36 // given store ID. Returns NULL if the profile doesn't exist or is not allowed 44 // given store ID. Returns NULL if the profile doesn't exist or is not allowed
37 // (e.g. if incognito mode is not enabled for the extension). 45 // (e.g. if incognito mode is not enabled for the extension).
38 Profile* ChooseProfileFromStoreId(const std::string& store_id, 46 Profile* ChooseProfileFromStoreId(const std::string& store_id,
39 Profile* profile, 47 Profile* profile,
40 bool include_incognito); 48 bool include_incognito);
41 49
42 // Returns the store ID for a particular user profile. 50 // Returns the store ID for a particular user profile.
43 const char* GetStoreIdFromProfile(Profile* profile); 51 const char* GetStoreIdFromProfile(Profile* profile);
44 52
45 // Constructs a Cookie object as defined by the cookies API. This function 53 // Allocates and construct a new Cookie object representing a cookie as defined
46 // allocates a new DictionaryValue object; the caller is responsible for 54 // by the cookies API.
47 // freeing it. 55 scoped_ptr<extensions::api::cookies::Cookie> CreateCookie(
48 base::DictionaryValue* CreateCookieValue(const net::CanonicalCookie& cookie, 56 const net::CanonicalCookie& cookie,
49 const std::string& store_id); 57 const std::string& store_id);
50 58
51 // Constructs a CookieStore object as defined by the cookies API. This function 59 // Allocates and constructs a new CookieStore object as defined by the cookies
52 // allocates a new DictionaryValue object; the caller is responsible for 60 // API.
53 // freeing it. 61 scoped_ptr<extensions::api::cookies::CookieStore> CreateCookieStore(
54 base::DictionaryValue* CreateCookieStoreValue(Profile* profile, 62 Profile* profile,
55 base::ListValue* tab_ids); 63 base::ListValue* tab_ids);
56 64
57 // Retrieves all cookies from the given cookie store corresponding to the given 65 // Retrieves all cookies from the given cookie store corresponding to the given
58 // URL. If the URL is empty, all cookies in the cookie store are retrieved. 66 // URL. If the URL is empty, all cookies in the cookie store are retrieved.
59 // This can only be called on the IO thread. 67 // This can only be called on the IO thread.
60 void GetCookieListFromStore( 68 void GetCookieListFromStore(
61 net::CookieStore* cookie_store, const GURL& url, 69 net::CookieStore* cookie_store, const GURL& url,
62 const net::CookieMonster::GetCookieListCallback& callback); 70 const net::CookieMonster::GetCookieListCallback& callback);
63 71
64 // Constructs a URL from a cookie's information for use in checking 72 // Constructs a URL from a cookie's information for use in checking
65 // a cookie against the extension's host permissions. The Secure 73 // a cookie against the extension's host permissions. The Secure
66 // property of the cookie defines the URL scheme, and the cookie's 74 // property of the cookie defines the URL scheme, and the cookie's
67 // domain becomes the URL host. 75 // domain becomes the URL host.
68 GURL GetURLFromCanonicalCookie(const net::CanonicalCookie& cookie); 76 GURL GetURLFromCanonicalCookie(
77 const net::CanonicalCookie& cookie);
69 78
70 // Looks through all cookies in the given cookie store, and appends to the 79 // Looks through all cookies in the given cookie store, and appends to the
71 // match list all the cookies that both match the given URL and cookie details 80 // match vector all the cookies that both match the given URL and cookie details
72 // and are allowed by extension host permissions. 81 // and are allowed by extension host permissions.
73 void AppendMatchingCookiesToList( 82 void AppendMatchingCookiesToVector(
74 const net::CookieList& all_cookies, 83 const net::CookieList& all_cookies, const GURL& url,
75 const std::string& store_id, 84 const extensions::api::cookies::GetAll::Params::Details* details,
76 const GURL& url, const base::DictionaryValue* details, 85 const Extension* extension, LinkedCookieVec* match_vector);
77 const Extension* extension,
78 base::ListValue* match_list);
79 86
80 // Appends the IDs of all tabs belonging to the given browser to the 87 // Appends the IDs of all tabs belonging to the given browser to the
81 // given list. 88 // given list.
82 void AppendToTabIdList(Browser* browser, base::ListValue* tab_ids); 89 void AppendToTabIdList(Browser* browser, base::ListValue* tab_ids);
83 90
84 // A class representing the cookie filter parameters passed into 91 // A class representing the cookie filter parameters passed into
85 // cookies.getAll(). 92 // cookies.getAll().
86 // This class is essentially a convenience wrapper for the details dictionary 93 // This class is essentially a convenience wrapper for the details dictionary
87 // passed into the cookies.getAll() API by the user. If the dictionary contains 94 // passed into the cookies.getAll() API by the user. If the dictionary contains
88 // no filter parameters, the MatchFilter will always trivially 95 // no filter parameters, the MatchFilter will always trivially
89 // match all cookies. 96 // match all cookies.
90 class MatchFilter { 97 class MatchFilter {
91 public: 98 public:
92 // Takes the details dictionary argument given by the user as input. 99 // Takes the details dictionary argument given by the user as input.
93 // This class does not take ownership of the lifetime of the DictionaryValue 100 // This class does not take ownership of the lifetime of the Details
94 // object. 101 // object.
95 explicit MatchFilter(const base::DictionaryValue* details); 102 explicit MatchFilter(
103 const extensions::api::cookies::GetAll::Params::Details* details);
96 104
97 // Returns true if the given cookie matches the properties in the match 105 // Returns true if the given cookie matches the properties in the match
98 // filter. 106 // filter.
99 bool MatchesCookie(const net::CanonicalCookie& cookie); 107 bool MatchesCookie(const net::CanonicalCookie& cookie);
100 108
101 private: 109 private:
102 // Returns true if the details dictionary contains a string with the given
103 // key and value. Also returns true if the dictionary doesn't contain the
104 // given key at all (trival match).
105 bool MatchesString(const char* key, const std::string& value);
106
107 // Returns true if the details dictionary contains a boolean with the given
108 // key and value. Also returns true if the dictionary doesn't contain the
109 // given key at all (trival match).
110 bool MatchesBoolean(const char* key, bool value);
111
112 // Returns true if the given cookie domain string matches the filter's 110 // Returns true if the given cookie domain string matches the filter's
113 // domain. Any cookie domain which is equal to or is a subdomain of the 111 // domain. Any cookie domain which is equal to or is a subdomain of the
114 // filter's domain will be matched; leading '.' characters indicating 112 // filter's domain will be matched; leading '.' characters indicating
115 // host-only domains have no meaning in the match filter domain (for 113 // host-only domains have no meaning in the match filter domain (for
116 // instance, a match filter domain of 'foo.bar.com' will be treated the same 114 // instance, a match filter domain of 'foo.bar.com' will be treated the same
117 // as '.foo.bar.com', and both will match cookies with domain values of 115 // as '.foo.bar.com', and both will match cookies with domain values of
118 // 'foo.bar.com', '.foo.bar.com', and 'baz.foo.bar.com'. 116 // 'foo.bar.com', '.foo.bar.com', and 'baz.foo.bar.com'.
119 bool MatchesDomain(const std::string& domain); 117 bool MatchesDomain(const std::string& domain);
120 118
121 const base::DictionaryValue* details_; 119 const extensions::api::cookies::GetAll::Params::Details* details_;
122 }; 120 };
123 121
124 } // namespace cookies_helpers 122 } // namespace cookies_helpers
125 } // namespace extensions 123 } // namespace extensions
126 124
127 #endif // CHROME_BROWSER_EXTENSIONS_API_COOKIES_COOKIES_HELPERS_H_ 125 #endif // CHROME_BROWSER_EXTENSIONS_API_COOKIES_COOKIES_HELPERS_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698