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

Side by Side Diff: third_party/WebKit/Source/modules/serviceworkers/NavigationPreloadManager.cpp

Issue 2451373003: service worker: Implement NavigationPreloadManager.setHeaderValue (Closed)
Patch Set: revise Created 4 years, 1 month 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 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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/serviceworkers/NavigationPreloadManager.h" 5 #include "modules/serviceworkers/NavigationPreloadManager.h"
6 6
7 #include "bindings/core/v8/CallbackPromiseAdapter.h"
7 #include "core/dom/DOMException.h" 8 #include "core/dom/DOMException.h"
8 #include "modules/serviceworkers/NavigationPreloadCallbacks.h" 9 #include "modules/serviceworkers/NavigationPreloadCallbacks.h"
9 #include "modules/serviceworkers/ServiceWorkerContainerClient.h" 10 #include "modules/serviceworkers/ServiceWorkerContainerClient.h"
10 #include "modules/serviceworkers/ServiceWorkerRegistration.h" 11 #include "modules/serviceworkers/ServiceWorkerRegistration.h"
11 12
12 namespace blink { 13 namespace blink {
13 14
14 ScriptPromise NavigationPreloadManager::enable(ScriptState* scriptState) { 15 ScriptPromise NavigationPreloadManager::enable(ScriptState* scriptState) {
15 return setEnabled(true, scriptState); 16 return setEnabled(true, scriptState);
16 } 17 }
17 18
18 ScriptPromise NavigationPreloadManager::disable(ScriptState* scriptState) { 19 ScriptPromise NavigationPreloadManager::disable(ScriptState* scriptState) {
19 return setEnabled(false, scriptState); 20 return setEnabled(false, scriptState);
20 } 21 }
21 22
22 ScriptPromise NavigationPreloadManager::setHeaderValue(ScriptState*, 23 ScriptPromise NavigationPreloadManager::setHeaderValue(ScriptState* scriptState,
23 const String& value) { 24 const String& value) {
horo 2016/10/31 03:32:52 It is not written in the spec yet, but I think we
falken 2016/10/31 08:32:08 Done. I used IsValidHttpHeaderValue which looks li
24 NOTIMPLEMENTED(); 25 ServiceWorkerContainerClient* client =
25 return ScriptPromise(); 26 ServiceWorkerContainerClient::from(m_registration->getExecutionContext());
27 if (!client || !client->provider()) {
28 return ScriptPromise::rejectWithDOMException(
29 scriptState, DOMException::create(InvalidStateError, "No provider."));
30 }
31 ScriptPromiseResolver* resolver = ScriptPromiseResolver::create(scriptState);
32 ScriptPromise promise = resolver->promise();
33 m_registration->webRegistration()->setNavigationPreloadHeader(
34 value, client->provider(),
35 wrapUnique(new SetNavigationPreloadHeaderCallbacks(resolver)));
36 return promise;
26 } 37 }
27 38
28 ScriptPromise NavigationPreloadManager::getState(ScriptState* scriptState) { 39 ScriptPromise NavigationPreloadManager::getState(ScriptState* scriptState) {
29 ServiceWorkerContainerClient* client = 40 ServiceWorkerContainerClient* client =
30 ServiceWorkerContainerClient::from(m_registration->getExecutionContext()); 41 ServiceWorkerContainerClient::from(m_registration->getExecutionContext());
31 if (!client || !client->provider()) { 42 if (!client || !client->provider()) {
32 return ScriptPromise::rejectWithDOMException( 43 return ScriptPromise::rejectWithDOMException(
33 scriptState, DOMException::create(InvalidStateError, "No provider.")); 44 scriptState, DOMException::create(InvalidStateError, "No provider."));
34 } 45 }
35 ScriptPromiseResolver* resolver = ScriptPromiseResolver::create(scriptState); 46 ScriptPromiseResolver* resolver = ScriptPromiseResolver::create(scriptState);
(...skipping 22 matching lines...) Expand all
58 enable, client->provider(), 69 enable, client->provider(),
59 wrapUnique(new EnableNavigationPreloadCallbacks(resolver))); 70 wrapUnique(new EnableNavigationPreloadCallbacks(resolver)));
60 return promise; 71 return promise;
61 } 72 }
62 73
63 DEFINE_TRACE(NavigationPreloadManager) { 74 DEFINE_TRACE(NavigationPreloadManager) {
64 visitor->trace(m_registration); 75 visitor->trace(m_registration);
65 } 76 }
66 77
67 } // namespace blink 78 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698