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

Side by Side Diff: third_party/WebKit/Source/modules/quota/StorageManager.cpp

Issue 1855623002: Implement quota estimation API from Storage spec (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Update webexposed expectations Created 4 years, 8 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 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 "modules/quota/StorageManager.h" 5 #include "modules/quota/StorageManager.h"
6 6
7 #include "bindings/core/v8/ScriptPromiseResolver.h" 7 #include "bindings/core/v8/ScriptPromiseResolver.h"
8 #include "bindings/modules/v8/V8StorageEstimate.h"
9 #include "core/dom/DOMError.h"
8 #include "core/dom/Document.h" 10 #include "core/dom/Document.h"
9 #include "core/dom/ExceptionCode.h" 11 #include "core/dom/ExceptionCode.h"
10 #include "modules/permissions/Permissions.h" 12 #include "modules/permissions/Permissions.h"
13 #include "modules/quota/StorageEstimate.h"
14 #include "platform/StorageQuotaCallbacks.h"
11 #include "public/platform/Platform.h" 15 #include "public/platform/Platform.h"
12 #include "public/platform/WebCallbacks.h" 16 #include "public/platform/WebCallbacks.h"
13 #include "public/platform/modules/permissions/WebPermissionClient.h" 17 #include "public/platform/modules/permissions/WebPermissionClient.h"
14 #include "public/platform/modules/permissions/WebPermissionStatus.h" 18 #include "public/platform/modules/permissions/WebPermissionStatus.h"
15 19
16 namespace blink { 20 namespace blink {
17 21
18 namespace { 22 namespace {
19 23
20 class DurableStorageQueryCallbacks final : public WebPermissionCallback { 24 class DurableStorageQueryCallbacks final : public WebPermissionCallback {
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after
62 } 66 }
63 void onError() override 67 void onError() override
64 { 68 {
65 ASSERT_NOT_REACHED(); 69 ASSERT_NOT_REACHED();
66 } 70 }
67 71
68 private: 72 private:
69 Persistent<ScriptPromiseResolver> m_resolver; 73 Persistent<ScriptPromiseResolver> m_resolver;
70 }; 74 };
71 75
76 class EstimateCallbacks final : public StorageQuotaCallbacks {
77 WTF_MAKE_NONCOPYABLE(EstimateCallbacks);
78 public:
79 explicit EstimateCallbacks(ScriptPromiseResolver* resolver)
80 : m_resolver(resolver) {}
81
82 ~EstimateCallbacks() override {}
83
84 void didQueryStorageUsageAndQuota(unsigned long long usageInBytes, unsigned long long quotaInBytes) override
85 {
86 StorageEstimate estimate;
87 estimate.setUsage(usageInBytes);
88 estimate.setQuota(quotaInBytes);
89 m_resolver->resolve(estimate);
kinuko 2016/04/20 05:56:32 So we're basically just going to expose these raw
jsbell 2016/04/20 19:38:04 Correct.
90 }
91
92 void didFail(WebStorageQuotaError error) override
93 {
94 // TODO: DOMException!
kinuko 2016/04/20 05:56:32 TODO(jsbell) ..?
jsbell 2016/04/20 19:38:04 Convered this (and below) to use DOMException. Not
95 m_resolver->reject(DOMError::create(static_cast<ExceptionCode>(error)));
96 }
97
98 DEFINE_INLINE_VIRTUAL_TRACE()
99 {
100 visitor->trace(m_resolver);
101 StorageQuotaCallbacks::trace(visitor);
102 }
103
104 private:
105 Member<ScriptPromiseResolver> m_resolver;
106 };
107
72 } // namespace 108 } // namespace
73 109
74 ScriptPromise StorageManager::requestPersistent(ScriptState* scriptState) 110 ScriptPromise StorageManager::requestPersistent(ScriptState* scriptState)
75 { 111 {
76 ScriptPromiseResolver* resolver = ScriptPromiseResolver::create(scriptState) ; 112 ScriptPromiseResolver* resolver = ScriptPromiseResolver::create(scriptState) ;
77 ScriptPromise promise = resolver->promise(); 113 ScriptPromise promise = resolver->promise();
78 ExecutionContext* executionContext = scriptState->getExecutionContext(); 114 ExecutionContext* executionContext = scriptState->getExecutionContext();
79 SecurityOrigin* securityOrigin = executionContext->getSecurityOrigin(); 115 SecurityOrigin* securityOrigin = executionContext->getSecurityOrigin();
80 // TODO(dgrogan): Is the isUnique() check covered by the later 116 // TODO(dgrogan): Is the isUnique() check covered by the later
81 // isSecureContext() check? If so, maybe remove it. Write a test if it 117 // isSecureContext() check? If so, maybe remove it. Write a test if it
(...skipping 24 matching lines...) Expand all
106 ScriptPromise promise = resolver->promise(); 142 ScriptPromise promise = resolver->promise();
107 WebPermissionClient* permissionClient = Permissions::getClient(scriptState-> getExecutionContext()); 143 WebPermissionClient* permissionClient = Permissions::getClient(scriptState-> getExecutionContext());
108 if (!permissionClient) { 144 if (!permissionClient) {
109 resolver->reject(DOMException::create(InvalidStateError, "In its current state, the global scope can't query permissions.")); 145 resolver->reject(DOMException::create(InvalidStateError, "In its current state, the global scope can't query permissions."));
110 return promise; 146 return promise;
111 } 147 }
112 permissionClient->queryPermission(WebPermissionTypeDurableStorage, KURL(KURL (), scriptState->getExecutionContext()->getSecurityOrigin()->toString()), new Du rableStorageQueryCallbacks(resolver)); 148 permissionClient->queryPermission(WebPermissionTypeDurableStorage, KURL(KURL (), scriptState->getExecutionContext()->getSecurityOrigin()->toString()), new Du rableStorageQueryCallbacks(resolver));
113 return promise; 149 return promise;
114 } 150 }
115 151
152 ScriptPromise StorageManager::estimate(ScriptState* scriptState)
153 {
154 ScriptPromiseResolver* resolver = ScriptPromiseResolver::create(scriptState) ;
155 ScriptPromise promise = resolver->promise();
156 ExecutionContext* executionContext = scriptState->getExecutionContext();
157 SecurityOrigin* securityOrigin = executionContext->getSecurityOrigin();
158 if (securityOrigin->isUnique()) {
159 resolver->reject(DOMError::create(NotSupportedError));
160 return promise;
161 }
162 // IDL has: [SecureContext]
163 String errorMessage;
164 if (!executionContext->isSecureContext(errorMessage)) {
165 resolver->reject(DOMException::create(SecurityError, errorMessage));
166 return promise;
167 }
168
169 KURL storagePartition = KURL(KURL(), securityOrigin->toString());
170 Platform::current()->queryStorageUsageAndQuota(storagePartition, WebStorageQ uotaTypeTemporary, new EstimateCallbacks(resolver));
171 return promise;
172 }
173
116 DEFINE_TRACE(StorageManager) 174 DEFINE_TRACE(StorageManager)
117 { 175 {
118 } 176 }
119 177
120 } // namespace blink 178 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698