Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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/background_fetch/BackgroundFetchBridge.h" | 5 #include "modules/background_fetch/BackgroundFetchBridge.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 #include "modules/background_fetch/BackgroundFetchOptions.h" | 8 #include "modules/background_fetch/BackgroundFetchOptions.h" |
| 9 #include "modules/background_fetch/BackgroundFetchRegistration.h" | 9 #include "modules/background_fetch/BackgroundFetchRegistration.h" |
| 10 #include "modules/background_fetch/BackgroundFetchTypeConverters.h" | |
|
dcheng
2017/03/21 07:03:20
Let's use typemapping on the Blink side. It'll sav
Peter Beverloo
2017/03/21 14:05:19
These types live in //Source/modules/, whereas the
| |
| 10 #include "modules/background_fetch/IconDefinition.h" | 11 #include "modules/background_fetch/IconDefinition.h" |
| 11 #include "public/platform/InterfaceProvider.h" | 12 #include "public/platform/InterfaceProvider.h" |
| 12 #include "public/platform/Platform.h" | 13 #include "public/platform/Platform.h" |
| 13 #include "public/platform/modules/serviceworker/WebServiceWorkerRegistration.h" | 14 #include "public/platform/modules/serviceworker/WebServiceWorkerRegistration.h" |
| 14 | 15 |
| 15 namespace blink { | 16 namespace blink { |
| 16 | 17 |
| 17 namespace { | |
| 18 | |
| 19 // Creates a new BackgroundFetchRegistration instance given a Service Worker | |
| 20 // Registration and a Mojo BackgroundFetchRegistrationPtr instance. | |
| 21 BackgroundFetchRegistration* CreateBackgroundFetchRegistration( | |
| 22 ServiceWorkerRegistration* serviceWorkerRegistration, | |
| 23 mojom::blink::BackgroundFetchRegistrationPtr registrationPtr) { | |
| 24 HeapVector<IconDefinition> icons; | |
| 25 | |
| 26 for (const auto& iconPtr : registrationPtr->icons) { | |
| 27 IconDefinition icon; | |
| 28 icon.setSrc(iconPtr->src); | |
| 29 icon.setSizes(iconPtr->sizes); | |
| 30 icon.setType(iconPtr->type); | |
| 31 | |
| 32 icons.push_back(icon); | |
| 33 } | |
| 34 | |
| 35 return new BackgroundFetchRegistration( | |
| 36 serviceWorkerRegistration, registrationPtr->tag, std::move(icons), | |
| 37 registrationPtr->total_download_size, registrationPtr->title); | |
| 38 } | |
| 39 | |
| 40 } // namespace | |
| 41 | |
| 42 // static | 18 // static |
| 43 BackgroundFetchBridge* BackgroundFetchBridge::from( | 19 BackgroundFetchBridge* BackgroundFetchBridge::from( |
| 44 ServiceWorkerRegistration* serviceWorkerRegistration) { | 20 ServiceWorkerRegistration* serviceWorkerRegistration) { |
| 45 DCHECK(serviceWorkerRegistration); | 21 DCHECK(serviceWorkerRegistration); |
| 46 | 22 |
| 47 BackgroundFetchBridge* bridge = static_cast<BackgroundFetchBridge*>( | 23 BackgroundFetchBridge* bridge = static_cast<BackgroundFetchBridge*>( |
| 48 Supplement<ServiceWorkerRegistration>::from(serviceWorkerRegistration, | 24 Supplement<ServiceWorkerRegistration>::from(serviceWorkerRegistration, |
| 49 supplementName())); | 25 supplementName())); |
| 50 | 26 |
| 51 if (!bridge) { | 27 if (!bridge) { |
| 52 bridge = new BackgroundFetchBridge(*serviceWorkerRegistration); | 28 bridge = new BackgroundFetchBridge(*serviceWorkerRegistration); |
| 53 Supplement<ServiceWorkerRegistration>::provideTo(*serviceWorkerRegistration, | 29 Supplement<ServiceWorkerRegistration>::provideTo(*serviceWorkerRegistration, |
| 54 supplementName(), bridge); | 30 supplementName(), bridge); |
| 55 } | 31 } |
| 56 | 32 |
| 57 return bridge; | 33 return bridge; |
| 58 } | 34 } |
| 59 | 35 |
| 60 // static | 36 // static |
| 61 const char* BackgroundFetchBridge::supplementName() { | 37 const char* BackgroundFetchBridge::supplementName() { |
| 62 return "BackgroundFetchBridge"; | 38 return "BackgroundFetchBridge"; |
| 63 } | 39 } |
| 64 | 40 |
| 65 BackgroundFetchBridge::BackgroundFetchBridge( | 41 BackgroundFetchBridge::BackgroundFetchBridge( |
| 66 ServiceWorkerRegistration& registration) | 42 ServiceWorkerRegistration& registration) |
| 67 : Supplement<ServiceWorkerRegistration>(registration) {} | 43 : Supplement<ServiceWorkerRegistration>(registration) {} |
| 68 | 44 |
| 69 BackgroundFetchBridge::~BackgroundFetchBridge() = default; | 45 BackgroundFetchBridge::~BackgroundFetchBridge() = default; |
| 70 | 46 |
| 47 void BackgroundFetchBridge::fetch( | |
| 48 const String& tag, | |
| 49 const BackgroundFetchOptions& options, | |
| 50 std::unique_ptr<RegistrationCallback> callback) { | |
| 51 getService()->Fetch( | |
| 52 supplementable()->webRegistration()->registrationId(), tag, | |
| 53 mojom::blink::BackgroundFetchOptions::From(options), | |
| 54 convertToBaseCallback( | |
| 55 WTF::bind(&BackgroundFetchBridge::didGetRegistration, | |
| 56 wrapPersistent(this), WTF::passed(std::move(callback))))); | |
| 57 } | |
| 58 | |
| 71 void BackgroundFetchBridge::abort(const String& tag) { | 59 void BackgroundFetchBridge::abort(const String& tag) { |
| 72 getService()->Abort(supplementable()->webRegistration()->registrationId(), | 60 getService()->Abort(supplementable()->webRegistration()->registrationId(), |
| 73 tag); | 61 tag); |
| 74 } | 62 } |
| 75 | 63 |
| 76 void BackgroundFetchBridge::updateUI( | 64 void BackgroundFetchBridge::updateUI( |
| 77 const String& tag, | 65 const String& tag, |
| 78 const String& title, | 66 const String& title, |
| 79 std::unique_ptr<UpdateUICallback> callback) { | 67 std::unique_ptr<UpdateUICallback> callback) { |
| 80 getService()->UpdateUI(supplementable()->webRegistration()->registrationId(), | 68 getService()->UpdateUI(supplementable()->webRegistration()->registrationId(), |
| 81 tag, title, | 69 tag, title, |
| 82 convertToBaseCallback(std::move(callback))); | 70 convertToBaseCallback(std::move(callback))); |
| 83 } | 71 } |
| 84 | 72 |
| 85 void BackgroundFetchBridge::getRegistration( | 73 void BackgroundFetchBridge::getRegistration( |
| 86 const String& tag, | 74 const String& tag, |
| 87 std::unique_ptr<GetRegistrationCallback> callback) { | 75 std::unique_ptr<RegistrationCallback> callback) { |
| 88 getService()->GetRegistration( | 76 getService()->GetRegistration( |
| 89 supplementable()->webRegistration()->registrationId(), tag, | 77 supplementable()->webRegistration()->registrationId(), tag, |
| 90 convertToBaseCallback( | 78 convertToBaseCallback( |
| 91 WTF::bind(&BackgroundFetchBridge::didGetRegistration, | 79 WTF::bind(&BackgroundFetchBridge::didGetRegistration, |
| 92 wrapPersistent(this), WTF::passed(std::move(callback))))); | 80 wrapPersistent(this), WTF::passed(std::move(callback))))); |
| 93 } | 81 } |
| 94 | 82 |
| 95 void BackgroundFetchBridge::didGetRegistration( | 83 void BackgroundFetchBridge::didGetRegistration( |
|
harkness
2017/03/21 11:30:00
optional: I'm glad that we're reusing the code for
Peter Beverloo
2017/03/21 13:46:27
Can you suggest a name that you think would be cle
| |
| 96 std::unique_ptr<GetRegistrationCallback> callback, | 84 std::unique_ptr<RegistrationCallback> callback, |
| 97 mojom::blink::BackgroundFetchError error, | 85 mojom::blink::BackgroundFetchError error, |
| 98 mojom::blink::BackgroundFetchRegistrationPtr registrationPtr) { | 86 mojom::blink::BackgroundFetchRegistrationPtr registrationPtr) { |
| 99 BackgroundFetchRegistration* registration = nullptr; | 87 BackgroundFetchRegistration* registration = |
| 88 registrationPtr.To<BackgroundFetchRegistration*>(); | |
| 100 | 89 |
| 101 if (registrationPtr) { | 90 if (registration) { |
| 102 DCHECK_EQ(error, mojom::blink::BackgroundFetchError::NONE); | 91 DCHECK_EQ(error, mojom::blink::BackgroundFetchError::NONE); |
| 103 registration = CreateBackgroundFetchRegistration( | 92 registration->setServiceWorkerRegistration(supplementable()); |
| 104 supplementable(), std::move(registrationPtr)); | |
| 105 } | 93 } |
| 106 | 94 |
| 107 (*callback)(error, registration); | 95 (*callback)(error, registration); |
| 108 } | 96 } |
| 109 | 97 |
| 110 void BackgroundFetchBridge::getTags(std::unique_ptr<GetTagsCallback> callback) { | 98 void BackgroundFetchBridge::getTags(std::unique_ptr<GetTagsCallback> callback) { |
| 111 getService()->GetTags(supplementable()->webRegistration()->registrationId(), | 99 getService()->GetTags(supplementable()->webRegistration()->registrationId(), |
| 112 convertToBaseCallback(std::move(callback))); | 100 convertToBaseCallback(std::move(callback))); |
| 113 } | 101 } |
| 114 | 102 |
| 115 mojom::blink::BackgroundFetchServicePtr& BackgroundFetchBridge::getService() { | 103 mojom::blink::BackgroundFetchServicePtr& BackgroundFetchBridge::getService() { |
| 116 if (!m_backgroundFetchService) { | 104 if (!m_backgroundFetchService) { |
| 117 Platform::current()->interfaceProvider()->getInterface( | 105 Platform::current()->interfaceProvider()->getInterface( |
| 118 mojo::MakeRequest(&m_backgroundFetchService)); | 106 mojo::MakeRequest(&m_backgroundFetchService)); |
| 119 } | 107 } |
| 120 return m_backgroundFetchService; | 108 return m_backgroundFetchService; |
| 121 } | 109 } |
| 122 | 110 |
| 123 } // namespace blink | 111 } // namespace blink |
| OLD | NEW |