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

Side by Side Diff: content/browser/storage_partition_impl.h

Issue 2592793002: Revert of Change how the quota system computes the total poolsize for temporary storage (Closed)
Patch Set: Created 4 years 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 #ifndef CONTENT_BROWSER_STORAGE_PARTITION_IMPL_H_ 5 #ifndef CONTENT_BROWSER_STORAGE_PARTITION_IMPL_H_
6 #define CONTENT_BROWSER_STORAGE_PARTITION_IMPL_H_ 6 #define CONTENT_BROWSER_STORAGE_PARTITION_IMPL_H_
7 7
8 #include <stdint.h> 8 #include <stdint.h>
9 9
10 #include <memory> 10 #include <memory>
11 11
12 #include "base/compiler_specific.h" 12 #include "base/compiler_specific.h"
13 #include "base/files/file_path.h" 13 #include "base/files/file_path.h"
14 #include "base/gtest_prod_util.h" 14 #include "base/gtest_prod_util.h"
15 #include "base/macros.h" 15 #include "base/macros.h"
16 #include "base/memory/ref_counted.h" 16 #include "base/memory/ref_counted.h"
17 #include "base/memory/weak_ptr.h"
18 #include "content/browser/appcache/chrome_appcache_service.h" 17 #include "content/browser/appcache/chrome_appcache_service.h"
19 #include "content/browser/background_sync/background_sync_context.h" 18 #include "content/browser/background_sync/background_sync_context.h"
20 #include "content/browser/broadcast_channel/broadcast_channel_provider.h" 19 #include "content/browser/broadcast_channel/broadcast_channel_provider.h"
21 #include "content/browser/cache_storage/cache_storage_context_impl.h" 20 #include "content/browser/cache_storage/cache_storage_context_impl.h"
22 #include "content/browser/dom_storage/dom_storage_context_wrapper.h" 21 #include "content/browser/dom_storage/dom_storage_context_wrapper.h"
23 #include "content/browser/host_zoom_level_context.h" 22 #include "content/browser/host_zoom_level_context.h"
24 #include "content/browser/indexed_db/indexed_db_context_impl.h" 23 #include "content/browser/indexed_db/indexed_db_context_impl.h"
25 #include "content/browser/notifications/platform_notification_context_impl.h" 24 #include "content/browser/notifications/platform_notification_context_impl.h"
26 #include "content/browser/payments/payment_app_context_impl.h" 25 #include "content/browser/payments/payment_app_context_impl.h"
27 #include "content/browser/service_worker/service_worker_context_wrapper.h" 26 #include "content/browser/service_worker/service_worker_context_wrapper.h"
(...skipping 131 matching lines...) Expand 10 before | Expand all | Expand 10 after
159 // StoragePartition's on-disk-storage. 158 // StoragePartition's on-disk-storage.
160 // 159 //
161 // If |in_memory| is true, the |relative_partition_path| is (ab)used as a way 160 // If |in_memory| is true, the |relative_partition_path| is (ab)used as a way
162 // of distinguishing different in-memory partitions, but nothing is persisted 161 // of distinguishing different in-memory partitions, but nothing is persisted
163 // on to disk. 162 // on to disk.
164 static std::unique_ptr<StoragePartitionImpl> Create( 163 static std::unique_ptr<StoragePartitionImpl> Create(
165 BrowserContext* context, 164 BrowserContext* context,
166 bool in_memory, 165 bool in_memory,
167 const base::FilePath& relative_partition_path); 166 const base::FilePath& relative_partition_path);
168 167
169 StoragePartitionImpl(BrowserContext* browser_context, 168 StoragePartitionImpl(
170 const base::FilePath& partition_path, 169 BrowserContext* browser_context,
171 storage::SpecialStoragePolicy* special_storage_policy); 170 const base::FilePath& partition_path,
171 storage::QuotaManager* quota_manager,
172 ChromeAppCacheService* appcache_service,
173 storage::FileSystemContext* filesystem_context,
174 storage::DatabaseTracker* database_tracker,
175 DOMStorageContextWrapper* dom_storage_context,
176 IndexedDBContextImpl* indexed_db_context,
177 CacheStorageContextImpl* cache_storage_context,
178 ServiceWorkerContextWrapper* service_worker_context,
179 storage::SpecialStoragePolicy* special_storage_policy,
180 HostZoomLevelContext* host_zoom_level_context,
181 PlatformNotificationContextImpl* platform_notification_context,
182 BackgroundSyncContext* background_sync_context,
183 PaymentAppContextImpl* payment_app_context,
184 scoped_refptr<BroadcastChannelProvider>broadcast_channel_provider);
172 185
173 // We will never have both remove_origin be populated and a cookie_matcher. 186 // We will never have both remove_origin be populated and a cookie_matcher.
174 void ClearDataImpl(uint32_t remove_mask, 187 void ClearDataImpl(uint32_t remove_mask,
175 uint32_t quota_storage_remove_mask, 188 uint32_t quota_storage_remove_mask,
176 const GURL& remove_origin, 189 const GURL& remove_origin,
177 const OriginMatcherFunction& origin_matcher, 190 const OriginMatcherFunction& origin_matcher,
178 const CookieMatcherFunction& cookie_matcher, 191 const CookieMatcherFunction& cookie_matcher,
179 net::URLRequestContextGetter* rq_context, 192 net::URLRequestContextGetter* rq_context,
180 const base::Time begin, 193 const base::Time begin,
181 const base::Time end, 194 const base::Time end,
182 const base::Closure& callback); 195 const base::Closure& callback);
183 196
184 // Used by StoragePartitionImplMap. 197 // Used by StoragePartitionImplMap.
185 // 198 //
186 // TODO(ajwong): These should be taken in the constructor and in Create() but 199 // TODO(ajwong): These should be taken in the constructor and in Create() but
187 // because the URLRequestContextGetter still lives in Profile with a tangled 200 // because the URLRequestContextGetter still lives in Profile with a tangled
188 // initialization, if we try to retrieve the URLRequestContextGetter() 201 // initialization, if we try to retrieve the URLRequestContextGetter()
189 // before the default StoragePartition is created, we end up reentering the 202 // before the default StoragePartition is created, we end up reentering the
190 // construction and double-initializing. For now, we retain the legacy 203 // construction and double-initializing. For now, we retain the legacy
191 // behavior while allowing StoragePartitionImpl to expose these accessors by 204 // behavior while allowing StoragePartitionImpl to expose these accessors by
192 // letting StoragePartitionImplMap call these two private settings at the 205 // letting StoragePartitionImplMap call these two private settings at the
193 // appropriate time. These should move back into the constructor once 206 // appropriate time. These should move back into the constructor once
194 // URLRequestContextGetter's lifetime is sorted out. We should also move the 207 // URLRequestContextGetter's lifetime is sorted out. We should also move the
195 // PostCreateInitialization() out of StoragePartitionImplMap. 208 // PostCreateInitialization() out of StoragePartitionImplMap.
196 void SetURLRequestContext( 209 void SetURLRequestContext(
197 net::URLRequestContextGetter* url_request_context); 210 net::URLRequestContextGetter* url_request_context);
198 void SetMediaURLRequestContext( 211 void SetMediaURLRequestContext(
199 net::URLRequestContextGetter* media_url_request_context); 212 net::URLRequestContextGetter* media_url_request_context);
200 213
201 // Function used by the quota system to ask the embedder for the
202 // storage configuration info.
203 void GetQuotaSettings(const storage::OptionalQuotaSettingsCallback& callback);
204
205 base::FilePath partition_path_; 214 base::FilePath partition_path_;
206 scoped_refptr<net::URLRequestContextGetter> url_request_context_; 215 scoped_refptr<net::URLRequestContextGetter> url_request_context_;
207 scoped_refptr<net::URLRequestContextGetter> media_url_request_context_; 216 scoped_refptr<net::URLRequestContextGetter> media_url_request_context_;
208 scoped_refptr<storage::QuotaManager> quota_manager_; 217 scoped_refptr<storage::QuotaManager> quota_manager_;
209 scoped_refptr<ChromeAppCacheService> appcache_service_; 218 scoped_refptr<ChromeAppCacheService> appcache_service_;
210 scoped_refptr<storage::FileSystemContext> filesystem_context_; 219 scoped_refptr<storage::FileSystemContext> filesystem_context_;
211 scoped_refptr<storage::DatabaseTracker> database_tracker_; 220 scoped_refptr<storage::DatabaseTracker> database_tracker_;
212 scoped_refptr<DOMStorageContextWrapper> dom_storage_context_; 221 scoped_refptr<DOMStorageContextWrapper> dom_storage_context_;
213 scoped_refptr<IndexedDBContextImpl> indexed_db_context_; 222 scoped_refptr<IndexedDBContextImpl> indexed_db_context_;
214 scoped_refptr<CacheStorageContextImpl> cache_storage_context_; 223 scoped_refptr<CacheStorageContextImpl> cache_storage_context_;
215 scoped_refptr<ServiceWorkerContextWrapper> service_worker_context_; 224 scoped_refptr<ServiceWorkerContextWrapper> service_worker_context_;
216 scoped_refptr<storage::SpecialStoragePolicy> special_storage_policy_; 225 scoped_refptr<storage::SpecialStoragePolicy> special_storage_policy_;
217 scoped_refptr<HostZoomLevelContext> host_zoom_level_context_; 226 scoped_refptr<HostZoomLevelContext> host_zoom_level_context_;
218 scoped_refptr<PlatformNotificationContextImpl> platform_notification_context_; 227 scoped_refptr<PlatformNotificationContextImpl> platform_notification_context_;
219 scoped_refptr<BackgroundSyncContext> background_sync_context_; 228 scoped_refptr<BackgroundSyncContext> background_sync_context_;
220 scoped_refptr<PaymentAppContextImpl> payment_app_context_; 229 scoped_refptr<PaymentAppContextImpl> payment_app_context_;
221 scoped_refptr<BroadcastChannelProvider> broadcast_channel_provider_; 230 scoped_refptr<BroadcastChannelProvider> broadcast_channel_provider_;
222 231
223 mojo::BindingSet<mojom::StoragePartitionService> bindings_; 232 mojo::BindingSet<mojom::StoragePartitionService> bindings_;
224 233
225 // Raw pointer that should always be valid. The BrowserContext owns the 234 // Raw pointer that should always be valid. The BrowserContext owns the
226 // StoragePartitionImplMap which then owns StoragePartitionImpl. When the 235 // StoragePartitionImplMap which then owns StoragePartitionImpl. When the
227 // BrowserContext is destroyed, |this| will be destroyed too. 236 // BrowserContext is destroyed, |this| will be destroyed too.
228 BrowserContext* browser_context_; 237 BrowserContext* browser_context_;
229 238
230 base::WeakPtrFactory<StoragePartitionImpl> weak_factory_;
231
232 DISALLOW_COPY_AND_ASSIGN(StoragePartitionImpl); 239 DISALLOW_COPY_AND_ASSIGN(StoragePartitionImpl);
233 }; 240 };
234 241
235 } // namespace content 242 } // namespace content
236 243
237 #endif // CONTENT_BROWSER_STORAGE_PARTITION_IMPL_H_ 244 #endif // CONTENT_BROWSER_STORAGE_PARTITION_IMPL_H_
OLDNEW
« no previous file with comments | « content/browser/quota/storage_monitor_unittest.cc ('k') | content/browser/storage_partition_impl.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698