OLD | NEW |
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 // Implements the Chrome Extensions Cookies API. | 5 // Implements the Chrome Extensions Cookies API. |
6 | 6 |
7 #include "chrome/browser/extensions/api/cookies/cookies_api.h" | 7 #include "chrome/browser/extensions/api/cookies/cookies_api.h" |
8 | 8 |
| 9 #include <memory> |
9 #include <utility> | 10 #include <utility> |
10 #include <vector> | 11 #include <vector> |
11 | 12 |
12 #include "base/bind.h" | 13 #include "base/bind.h" |
13 #include "base/json/json_writer.h" | 14 #include "base/json/json_writer.h" |
14 #include "base/lazy_instance.h" | 15 #include "base/lazy_instance.h" |
15 #include "base/memory/linked_ptr.h" | 16 #include "base/memory/linked_ptr.h" |
16 #include "base/memory/scoped_ptr.h" | |
17 #include "base/time/time.h" | 17 #include "base/time/time.h" |
18 #include "base/values.h" | 18 #include "base/values.h" |
19 #include "chrome/browser/chrome_notification_types.h" | 19 #include "chrome/browser/chrome_notification_types.h" |
20 #include "chrome/browser/extensions/api/cookies/cookies_api_constants.h" | 20 #include "chrome/browser/extensions/api/cookies/cookies_api_constants.h" |
21 #include "chrome/browser/extensions/api/cookies/cookies_helpers.h" | 21 #include "chrome/browser/extensions/api/cookies/cookies_helpers.h" |
22 #include "chrome/browser/profiles/profile.h" | 22 #include "chrome/browser/profiles/profile.h" |
23 #include "chrome/browser/ui/browser.h" | 23 #include "chrome/browser/ui/browser.h" |
24 #include "chrome/browser/ui/browser_list.h" | 24 #include "chrome/browser/ui/browser_list.h" |
25 #include "chrome/common/extensions/api/cookies.h" | 25 #include "chrome/common/extensions/api/cookies.h" |
26 #include "content/public/browser/browser_thread.h" | 26 #include "content/public/browser/browser_thread.h" |
(...skipping 105 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
132 break; | 132 break; |
133 | 133 |
134 default: | 134 default: |
135 NOTREACHED(); | 135 NOTREACHED(); |
136 } | 136 } |
137 } | 137 } |
138 | 138 |
139 void CookiesEventRouter::CookieChanged( | 139 void CookiesEventRouter::CookieChanged( |
140 Profile* profile, | 140 Profile* profile, |
141 ChromeCookieDetails* details) { | 141 ChromeCookieDetails* details) { |
142 scoped_ptr<base::ListValue> args(new base::ListValue()); | 142 std::unique_ptr<base::ListValue> args(new base::ListValue()); |
143 base::DictionaryValue* dict = new base::DictionaryValue(); | 143 base::DictionaryValue* dict = new base::DictionaryValue(); |
144 dict->SetBoolean(keys::kRemovedKey, details->removed); | 144 dict->SetBoolean(keys::kRemovedKey, details->removed); |
145 | 145 |
146 cookies::Cookie cookie = cookies_helpers::CreateCookie( | 146 cookies::Cookie cookie = cookies_helpers::CreateCookie( |
147 *details->cookie, cookies_helpers::GetStoreIdFromProfile(profile)); | 147 *details->cookie, cookies_helpers::GetStoreIdFromProfile(profile)); |
148 dict->Set(keys::kCookieKey, cookie.ToValue()); | 148 dict->Set(keys::kCookieKey, cookie.ToValue()); |
149 | 149 |
150 // Map the internal cause to an external string. | 150 // Map the internal cause to an external string. |
151 std::string cause; | 151 std::string cause; |
152 switch (details->cause) { | 152 switch (details->cause) { |
(...skipping 23 matching lines...) Expand all Loading... |
176 dict->SetString(keys::kCauseKey, cause); | 176 dict->SetString(keys::kCauseKey, cause); |
177 | 177 |
178 args->Append(dict); | 178 args->Append(dict); |
179 | 179 |
180 GURL cookie_domain = | 180 GURL cookie_domain = |
181 cookies_helpers::GetURLFromCanonicalCookie(*details->cookie); | 181 cookies_helpers::GetURLFromCanonicalCookie(*details->cookie); |
182 DispatchEvent(profile, events::COOKIES_ON_CHANGED, | 182 DispatchEvent(profile, events::COOKIES_ON_CHANGED, |
183 cookies::OnChanged::kEventName, std::move(args), cookie_domain); | 183 cookies::OnChanged::kEventName, std::move(args), cookie_domain); |
184 } | 184 } |
185 | 185 |
186 void CookiesEventRouter::DispatchEvent(content::BrowserContext* context, | 186 void CookiesEventRouter::DispatchEvent( |
187 events::HistogramValue histogram_value, | 187 content::BrowserContext* context, |
188 const std::string& event_name, | 188 events::HistogramValue histogram_value, |
189 scoped_ptr<base::ListValue> event_args, | 189 const std::string& event_name, |
190 GURL& cookie_domain) { | 190 std::unique_ptr<base::ListValue> event_args, |
| 191 GURL& cookie_domain) { |
191 EventRouter* router = context ? EventRouter::Get(context) : NULL; | 192 EventRouter* router = context ? EventRouter::Get(context) : NULL; |
192 if (!router) | 193 if (!router) |
193 return; | 194 return; |
194 scoped_ptr<Event> event( | 195 std::unique_ptr<Event> event( |
195 new Event(histogram_value, event_name, std::move(event_args))); | 196 new Event(histogram_value, event_name, std::move(event_args))); |
196 event->restrict_to_browser_context = context; | 197 event->restrict_to_browser_context = context; |
197 event->event_url = cookie_domain; | 198 event->event_url = cookie_domain; |
198 router->BroadcastEvent(std::move(event)); | 199 router->BroadcastEvent(std::move(event)); |
199 } | 200 } |
200 | 201 |
201 CookiesGetFunction::CookiesGetFunction() { | 202 CookiesGetFunction::CookiesGetFunction() { |
202 } | 203 } |
203 | 204 |
204 CookiesGetFunction::~CookiesGetFunction() { | 205 CookiesGetFunction::~CookiesGetFunction() { |
(...skipping 323 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
528 } | 529 } |
529 | 530 |
530 void CookiesRemoveFunction::RespondOnUIThread() { | 531 void CookiesRemoveFunction::RespondOnUIThread() { |
531 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 532 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
532 SendResponse(true); | 533 SendResponse(true); |
533 } | 534 } |
534 | 535 |
535 bool CookiesGetAllCookieStoresFunction::RunSync() { | 536 bool CookiesGetAllCookieStoresFunction::RunSync() { |
536 Profile* original_profile = GetProfile(); | 537 Profile* original_profile = GetProfile(); |
537 DCHECK(original_profile); | 538 DCHECK(original_profile); |
538 scoped_ptr<base::ListValue> original_tab_ids(new base::ListValue()); | 539 std::unique_ptr<base::ListValue> original_tab_ids(new base::ListValue()); |
539 Profile* incognito_profile = NULL; | 540 Profile* incognito_profile = NULL; |
540 scoped_ptr<base::ListValue> incognito_tab_ids; | 541 std::unique_ptr<base::ListValue> incognito_tab_ids; |
541 if (include_incognito() && GetProfile()->HasOffTheRecordProfile()) { | 542 if (include_incognito() && GetProfile()->HasOffTheRecordProfile()) { |
542 incognito_profile = GetProfile()->GetOffTheRecordProfile(); | 543 incognito_profile = GetProfile()->GetOffTheRecordProfile(); |
543 if (incognito_profile) | 544 if (incognito_profile) |
544 incognito_tab_ids.reset(new base::ListValue()); | 545 incognito_tab_ids.reset(new base::ListValue()); |
545 } | 546 } |
546 DCHECK(original_profile != incognito_profile); | 547 DCHECK(original_profile != incognito_profile); |
547 | 548 |
548 // Iterate through all browser instances, and for each browser, | 549 // Iterate through all browser instances, and for each browser, |
549 // add its tab IDs to either the regular or incognito tab ID list depending | 550 // add its tab IDs to either the regular or incognito tab ID list depending |
550 // whether the browser is regular or incognito. | 551 // whether the browser is regular or incognito. |
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
591 BrowserContextKeyedAPIFactory<CookiesAPI>* CookiesAPI::GetFactoryInstance() { | 592 BrowserContextKeyedAPIFactory<CookiesAPI>* CookiesAPI::GetFactoryInstance() { |
592 return g_factory.Pointer(); | 593 return g_factory.Pointer(); |
593 } | 594 } |
594 | 595 |
595 void CookiesAPI::OnListenerAdded(const EventListenerInfo& details) { | 596 void CookiesAPI::OnListenerAdded(const EventListenerInfo& details) { |
596 cookies_event_router_.reset(new CookiesEventRouter(browser_context_)); | 597 cookies_event_router_.reset(new CookiesEventRouter(browser_context_)); |
597 EventRouter::Get(browser_context_)->UnregisterObserver(this); | 598 EventRouter::Get(browser_context_)->UnregisterObserver(this); |
598 } | 599 } |
599 | 600 |
600 } // namespace extensions | 601 } // namespace extensions |
OLD | NEW |