| OLD | NEW |
| 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" | 8 #include "bindings/modules/v8/V8StorageEstimate.h" |
| 9 #include "core/dom/DOMException.h" | 9 #include "core/dom/DOMException.h" |
| 10 #include "core/dom/Document.h" | 10 #include "core/dom/Document.h" |
| 11 #include "core/dom/ExceptionCode.h" | 11 #include "core/dom/ExceptionCode.h" |
| 12 #include "modules/permissions/Permissions.h" | 12 #include "modules/permissions/PermissionUtils.h" |
| 13 #include "modules/quota/StorageEstimate.h" | 13 #include "modules/quota/StorageEstimate.h" |
| 14 #include "platform/StorageQuotaCallbacks.h" | 14 #include "platform/StorageQuotaCallbacks.h" |
| 15 #include "platform/UserGestureIndicator.h" | 15 #include "platform/UserGestureIndicator.h" |
| 16 #include "public/platform/Platform.h" | 16 #include "public/platform/Platform.h" |
| 17 #include "wtf/Functional.h" | 17 #include "wtf/Functional.h" |
| 18 | 18 |
| 19 namespace blink { | 19 namespace blink { |
| 20 | 20 |
| 21 using mojom::blink::PermissionName; | 21 using mojom::blink::PermissionName; |
| 22 using mojom::blink::PermissionService; | 22 using mojom::blink::PermissionService; |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 76 ASSERT(executionContext->isDocument()); | 76 ASSERT(executionContext->isDocument()); |
| 77 PermissionService* permissionService = | 77 PermissionService* permissionService = |
| 78 getPermissionService(scriptState->getExecutionContext()); | 78 getPermissionService(scriptState->getExecutionContext()); |
| 79 if (!permissionService) { | 79 if (!permissionService) { |
| 80 resolver->reject(DOMException::create( | 80 resolver->reject(DOMException::create( |
| 81 InvalidStateError, | 81 InvalidStateError, |
| 82 "In its current state, the global scope can't request permissions.")); | 82 "In its current state, the global scope can't request permissions.")); |
| 83 return promise; | 83 return promise; |
| 84 } | 84 } |
| 85 permissionService->RequestPermission( | 85 permissionService->RequestPermission( |
| 86 PermissionName::DURABLE_STORAGE, | 86 createPermissionDescriptor(PermissionName::DURABLE_STORAGE), |
| 87 scriptState->getExecutionContext()->getSecurityOrigin(), | 87 scriptState->getExecutionContext()->getSecurityOrigin(), |
| 88 UserGestureIndicator::processingUserGesture(), | 88 UserGestureIndicator::processingUserGesture(), |
| 89 convertToBaseCallback( | 89 convertToBaseCallback( |
| 90 WTF::bind(&StorageManager::permissionRequestComplete, | 90 WTF::bind(&StorageManager::permissionRequestComplete, |
| 91 wrapPersistent(this), wrapPersistent(resolver)))); | 91 wrapPersistent(this), wrapPersistent(resolver)))); |
| 92 | 92 |
| 93 return promise; | 93 return promise; |
| 94 } | 94 } |
| 95 | 95 |
| 96 ScriptPromise StorageManager::persisted(ScriptState* scriptState) { | 96 ScriptPromise StorageManager::persisted(ScriptState* scriptState) { |
| 97 ScriptPromiseResolver* resolver = ScriptPromiseResolver::create(scriptState); | 97 ScriptPromiseResolver* resolver = ScriptPromiseResolver::create(scriptState); |
| 98 ScriptPromise promise = resolver->promise(); | 98 ScriptPromise promise = resolver->promise(); |
| 99 PermissionService* permissionService = | 99 PermissionService* permissionService = |
| 100 getPermissionService(scriptState->getExecutionContext()); | 100 getPermissionService(scriptState->getExecutionContext()); |
| 101 if (!permissionService) { | 101 if (!permissionService) { |
| 102 resolver->reject(DOMException::create( | 102 resolver->reject(DOMException::create( |
| 103 InvalidStateError, | 103 InvalidStateError, |
| 104 "In its current state, the global scope can't query permissions.")); | 104 "In its current state, the global scope can't query permissions.")); |
| 105 return promise; | 105 return promise; |
| 106 } | 106 } |
| 107 permissionService->HasPermission( | 107 permissionService->HasPermission( |
| 108 PermissionName::DURABLE_STORAGE, | 108 createPermissionDescriptor(PermissionName::DURABLE_STORAGE), |
| 109 scriptState->getExecutionContext()->getSecurityOrigin(), | 109 scriptState->getExecutionContext()->getSecurityOrigin(), |
| 110 convertToBaseCallback( | 110 convertToBaseCallback( |
| 111 WTF::bind(&StorageManager::permissionRequestComplete, | 111 WTF::bind(&StorageManager::permissionRequestComplete, |
| 112 wrapPersistent(this), wrapPersistent(resolver)))); | 112 wrapPersistent(this), wrapPersistent(resolver)))); |
| 113 return promise; | 113 return promise; |
| 114 } | 114 } |
| 115 | 115 |
| 116 ScriptPromise StorageManager::estimate(ScriptState* scriptState) { | 116 ScriptPromise StorageManager::estimate(ScriptState* scriptState) { |
| 117 ScriptPromiseResolver* resolver = ScriptPromiseResolver::create(scriptState); | 117 ScriptPromiseResolver* resolver = ScriptPromiseResolver::create(scriptState); |
| 118 ScriptPromise promise = resolver->promise(); | 118 ScriptPromise promise = resolver->promise(); |
| (...skipping 12 matching lines...) Expand all Loading... |
| 131 | 131 |
| 132 KURL storagePartition = KURL(KURL(), securityOrigin->toString()); | 132 KURL storagePartition = KURL(KURL(), securityOrigin->toString()); |
| 133 Platform::current()->queryStorageUsageAndQuota( | 133 Platform::current()->queryStorageUsageAndQuota( |
| 134 storagePartition, WebStorageQuotaTypeTemporary, | 134 storagePartition, WebStorageQuotaTypeTemporary, |
| 135 new EstimateCallbacks(resolver)); | 135 new EstimateCallbacks(resolver)); |
| 136 return promise; | 136 return promise; |
| 137 } | 137 } |
| 138 | 138 |
| 139 DEFINE_TRACE(StorageManager) {} | 139 DEFINE_TRACE(StorageManager) {} |
| 140 | 140 |
| 141 mojom::blink::PermissionService* StorageManager::getPermissionService( | 141 PermissionService* StorageManager::getPermissionService( |
| 142 ExecutionContext* executionContext) { | 142 ExecutionContext* executionContext) { |
| 143 if (!m_permissionService && | 143 if (!m_permissionService && |
| 144 Permissions::connectToService(executionContext, | 144 connectToPermissionService(executionContext, |
| 145 mojo::GetProxy(&m_permissionService))) | 145 mojo::GetProxy(&m_permissionService))) |
| 146 m_permissionService.set_connection_error_handler(convertToBaseCallback( | 146 m_permissionService.set_connection_error_handler(convertToBaseCallback( |
| 147 WTF::bind(&StorageManager::permissionServiceConnectionError, | 147 WTF::bind(&StorageManager::permissionServiceConnectionError, |
| 148 wrapWeakPersistent(this)))); | 148 wrapWeakPersistent(this)))); |
| 149 return m_permissionService.get(); | 149 return m_permissionService.get(); |
| 150 } | 150 } |
| 151 | 151 |
| 152 void StorageManager::permissionServiceConnectionError() { | 152 void StorageManager::permissionServiceConnectionError() { |
| 153 m_permissionService.reset(); | 153 m_permissionService.reset(); |
| 154 } | 154 } |
| 155 | 155 |
| 156 void StorageManager::permissionRequestComplete(ScriptPromiseResolver* resolver, | 156 void StorageManager::permissionRequestComplete(ScriptPromiseResolver* resolver, |
| 157 PermissionStatus status) { | 157 PermissionStatus status) { |
| 158 if (!resolver->getExecutionContext() || | 158 if (!resolver->getExecutionContext() || |
| 159 resolver->getExecutionContext()->activeDOMObjectsAreStopped()) | 159 resolver->getExecutionContext()->activeDOMObjectsAreStopped()) |
| 160 return; | 160 return; |
| 161 resolver->resolve(status == PermissionStatus::GRANTED); | 161 resolver->resolve(status == PermissionStatus::GRANTED); |
| 162 } | 162 } |
| 163 | 163 |
| 164 } // namespace blink | 164 } // namespace blink |
| OLD | NEW |