OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 #include <stddef.h> | 5 #include <stddef.h> |
6 | 6 |
| 7 #include <cstdint> |
| 8 |
7 #include "base/bind.h" | 9 #include "base/bind.h" |
8 #include "base/command_line.h" | 10 #include "base/command_line.h" |
9 #include "base/macros.h" | 11 #include "base/macros.h" |
10 #include "base/memory/ref_counted.h" | 12 #include "base/memory/ref_counted.h" |
11 #include "build/build_config.h" | 13 #include "build/build_config.h" |
12 #include "chrome/browser/browser_shutdown.h" | 14 #include "chrome/browser/browser_shutdown.h" |
13 #include "chrome/browser/prefs/session_startup_pref.h" | 15 #include "chrome/browser/prefs/session_startup_pref.h" |
14 #include "chrome/browser/profiles/profile.h" | 16 #include "chrome/browser/profiles/profile.h" |
15 #include "chrome/browser/ui/startup/startup_browser_creator.h" | 17 #include "chrome/browser/ui/startup/startup_browser_creator.h" |
16 #include "content/public/browser/browser_context.h" | 18 #include "content/public/browser/browser_context.h" |
17 #include "content/public/browser/browser_thread.h" | 19 #include "content/public/browser/browser_thread.h" |
18 #include "content/public/browser/dom_storage_context.h" | 20 #include "content/public/browser/dom_storage_context.h" |
19 #include "content/public/browser/local_storage_usage_info.h" | 21 #include "content/public/browser/local_storage_usage_info.h" |
20 #include "content/public/browser/storage_partition.h" | 22 #include "content/public/browser/storage_partition.h" |
21 #include "net/cookies/cookie_store.h" | 23 #include "net/cookies/cookie_store.h" |
22 #include "net/cookies/cookie_util.h" | 24 #include "net/cookies/cookie_util.h" |
23 #include "net/url_request/url_request_context.h" | 25 #include "net/url_request/url_request_context.h" |
24 #include "net/url_request/url_request_context_getter.h" | 26 #include "net/url_request/url_request_context_getter.h" |
25 #include "storage/browser/quota/special_storage_policy.h" | 27 #include "storage/browser/quota/special_storage_policy.h" |
26 | 28 |
27 namespace { | 29 namespace { |
28 | 30 |
29 void CookieDeleted(int num_cookies_deleted) { | 31 void CookieDeleted(uint32_t num_cookies_deleted) { |
30 DCHECK_EQ(1, num_cookies_deleted); | 32 DCHECK_EQ(1u, num_cookies_deleted); |
31 } | 33 } |
32 | 34 |
33 class SessionDataDeleter | 35 class SessionDataDeleter |
34 : public base::RefCountedThreadSafe<SessionDataDeleter> { | 36 : public base::RefCountedThreadSafe<SessionDataDeleter> { |
35 public: | 37 public: |
36 SessionDataDeleter(storage::SpecialStoragePolicy* storage_policy, | 38 SessionDataDeleter(storage::SpecialStoragePolicy* storage_policy, |
37 bool delete_only_by_session_only_policy); | 39 bool delete_only_by_session_only_policy); |
38 | 40 |
39 void Run( | 41 void Run( |
40 content::StoragePartition* storage_partition, | 42 content::StoragePartition* storage_partition, |
(...skipping 11 matching lines...) Expand all Loading... |
52 | 54 |
53 // Deletes all cookies that are session only if | 55 // Deletes all cookies that are session only if |
54 // |delete_only_by_session_only_policy_| is false. Once completed or skipped, | 56 // |delete_only_by_session_only_policy_| is false. Once completed or skipped, |
55 // this arranges for DeleteSessionOnlyOriginCookies to be called with a list | 57 // this arranges for DeleteSessionOnlyOriginCookies to be called with a list |
56 // of all remaining cookies. | 58 // of all remaining cookies. |
57 void DeleteSessionCookiesOnIOThread( | 59 void DeleteSessionCookiesOnIOThread( |
58 scoped_refptr<net::URLRequestContextGetter> url_request_context_getter); | 60 scoped_refptr<net::URLRequestContextGetter> url_request_context_getter); |
59 | 61 |
60 // Called when all session-only cookies have been deleted. | 62 // Called when all session-only cookies have been deleted. |
61 void DeleteSessionCookiesDone(net::CookieStore* cookie_store, | 63 void DeleteSessionCookiesDone(net::CookieStore* cookie_store, |
62 int num_deleted); | 64 uint32_t num_deleted); |
63 | 65 |
64 // Deletes the cookies in |cookies| that are for origins which are | 66 // Deletes the cookies in |cookies| that are for origins which are |
65 // session-only. | 67 // session-only. |
66 void DeleteSessionOnlyOriginCookies(net::CookieStore* cookie_store, | 68 void DeleteSessionOnlyOriginCookies(net::CookieStore* cookie_store, |
67 const net::CookieList& cookies); | 69 const net::CookieList& cookies); |
68 | 70 |
69 scoped_refptr<storage::SpecialStoragePolicy> storage_policy_; | 71 scoped_refptr<storage::SpecialStoragePolicy> storage_policy_; |
70 const bool delete_only_by_session_only_policy_; | 72 const bool delete_only_by_session_only_policy_; |
71 | 73 |
72 DISALLOW_COPY_AND_ASSIGN(SessionDataDeleter); | 74 DISALLOW_COPY_AND_ASSIGN(SessionDataDeleter); |
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
127 base::Unretained(cookie_store))); | 129 base::Unretained(cookie_store))); |
128 } else { | 130 } else { |
129 cookie_store->DeleteSessionCookiesAsync( | 131 cookie_store->DeleteSessionCookiesAsync( |
130 base::Bind(&SessionDataDeleter::DeleteSessionCookiesDone, this, | 132 base::Bind(&SessionDataDeleter::DeleteSessionCookiesDone, this, |
131 base::Unretained(cookie_store))); | 133 base::Unretained(cookie_store))); |
132 } | 134 } |
133 } | 135 } |
134 | 136 |
135 void SessionDataDeleter::DeleteSessionCookiesDone( | 137 void SessionDataDeleter::DeleteSessionCookiesDone( |
136 net::CookieStore* cookie_store, | 138 net::CookieStore* cookie_store, |
137 int num_deleted) { | 139 uint32_t num_deleted) { |
138 // If these callbacks are invoked, |cookie_store| is gauranteed to still | 140 // If these callbacks are invoked, |cookie_store| is gauranteed to still |
139 // exist, since deleting the CookieStore will cancel pending callbacks. | 141 // exist, since deleting the CookieStore will cancel pending callbacks. |
140 cookie_store->GetAllCookiesAsync( | 142 cookie_store->GetAllCookiesAsync( |
141 base::Bind(&SessionDataDeleter::DeleteSessionOnlyOriginCookies, this, | 143 base::Bind(&SessionDataDeleter::DeleteSessionOnlyOriginCookies, this, |
142 base::Unretained(cookie_store))); | 144 base::Unretained(cookie_store))); |
143 } | 145 } |
144 | 146 |
145 void SessionDataDeleter::DeleteSessionOnlyOriginCookies( | 147 void SessionDataDeleter::DeleteSessionOnlyOriginCookies( |
146 net::CookieStore* cookie_store, | 148 net::CookieStore* cookie_store, |
147 const net::CookieList& cookies) { | 149 const net::CookieList& cookies) { |
(...skipping 26 matching lines...) Expand all Loading... |
174 StartupBrowserCreator::GetSessionStartupPref( | 176 StartupBrowserCreator::GetSessionStartupPref( |
175 *base::CommandLine::ForCurrentProcess(), profile).type; | 177 *base::CommandLine::ForCurrentProcess(), profile).type; |
176 #endif | 178 #endif |
177 | 179 |
178 scoped_refptr<SessionDataDeleter> deleter( | 180 scoped_refptr<SessionDataDeleter> deleter( |
179 new SessionDataDeleter(profile->GetSpecialStoragePolicy(), | 181 new SessionDataDeleter(profile->GetSpecialStoragePolicy(), |
180 startup_pref_type == SessionStartupPref::LAST)); | 182 startup_pref_type == SessionStartupPref::LAST)); |
181 deleter->Run(Profile::GetDefaultStoragePartition(profile), | 183 deleter->Run(Profile::GetDefaultStoragePartition(profile), |
182 profile->GetRequestContext()); | 184 profile->GetRequestContext()); |
183 } | 185 } |
OLD | NEW |