Index: Source/modules/geofencing/Geofencing.cpp |
diff --git a/Source/modules/geofencing/Geofencing.cpp b/Source/modules/geofencing/Geofencing.cpp |
index 59d8b975755550e0b2f48b7a08e7fda81d16acc8..23befb5e89bb0b85e362a1f3d3bf43e1a763c04c 100644 |
--- a/Source/modules/geofencing/Geofencing.cpp |
+++ b/Source/modules/geofencing/Geofencing.cpp |
@@ -5,12 +5,63 @@ |
#include "config.h" |
#include "modules/geofencing/Geofencing.h" |
+#include "bindings/core/v8/CallbackPromiseAdapter.h" |
#include "bindings/core/v8/ScriptPromise.h" |
+#include "bindings/core/v8/ScriptPromiseResolver.h" |
#include "core/dom/DOMException.h" |
#include "core/dom/ExceptionCode.h" |
+#include "modules/geofencing/GeofencingError.h" |
+#include "modules/geofencing/GeofencingRegion.h" |
+#include "public/platform/Platform.h" |
+#include "public/platform/WebGeofencingProvider.h" |
namespace blink { |
+namespace { |
+ |
+// Copy of same class in ServiceWorkerContainer.cpp |
+class UndefinedValue { |
+public: |
+ typedef blink::WebGeofencingError WebType; |
+ static V8UndefinedType take(ScriptPromiseResolver* resolver, WebType* value) |
+ { |
+ ASSERT(!value); // Anything passed here will be leaked. |
+ return V8UndefinedType(); |
+ } |
+ |
+ static void dispose(WebType* value) |
+ { |
+ ASSERT(!value); // Anything passed here will be leaked. |
+ } |
+ |
+private: |
+ UndefinedValue(); |
+}; |
+ |
+class RegionArray { |
+public: |
+ typedef blink::WebVector<blink::WebGeofencingRegion> WebType; |
+ static HeapVector<Member<GeofencingRegion> > take(ScriptPromiseResolver* resolver, WebType* regionsRaw) |
+ { |
+ OwnPtr<WebType> webRegions = adoptPtr(regionsRaw); |
+ HeapVector<Member<GeofencingRegion> > regions; |
+ for (size_t i = 0; i < webRegions->size(); ++i) { |
+ regions.append(GeofencingRegion::createFromWebRegion((*webRegions)[i])); |
+ } |
+ return regions; |
+ } |
+ |
+ static void dispose(WebType* regionsRaw) |
+ { |
+ delete regionsRaw; |
+ } |
+ |
+private: |
+ RegionArray(); |
+}; |
+ |
+} // namespace |
+ |
Geofencing::Geofencing() |
{ |
ScriptWrappable::init(this); |
@@ -18,17 +69,41 @@ Geofencing::Geofencing() |
ScriptPromise Geofencing::registerRegion(ScriptState* scriptState, GeofencingRegion* region) |
{ |
- return ScriptPromise::rejectWithDOMException(scriptState, DOMException::create(NotSupportedError)); |
+ WebGeofencingProvider* provider = Platform::current()->geofencingProvider(); |
+ if (!provider) { |
+ return ScriptPromise::rejectWithDOMException(scriptState, DOMException::create(NotSupportedError)); |
+ } |
+ |
+ RefPtr<ScriptPromiseResolver> resolver = ScriptPromiseResolver::create(scriptState); |
+ ScriptPromise promise = resolver->promise(); |
+ provider->registerRegion(region->webRegion(), new CallbackPromiseAdapter<UndefinedValue, GeofencingError>(resolver)); |
+ return promise; |
} |
ScriptPromise Geofencing::unregisterRegion(ScriptState* scriptState, const String& regionId) |
{ |
- return ScriptPromise::rejectWithDOMException(scriptState, DOMException::create(NotSupportedError)); |
+ WebGeofencingProvider* provider = Platform::current()->geofencingProvider(); |
+ if (!provider) { |
+ return ScriptPromise::rejectWithDOMException(scriptState, DOMException::create(NotSupportedError)); |
+ } |
+ |
+ RefPtr<ScriptPromiseResolver> resolver = ScriptPromiseResolver::create(scriptState); |
+ ScriptPromise promise = resolver->promise(); |
+ provider->unregisterRegion(regionId, new CallbackPromiseAdapter<UndefinedValue, GeofencingError>(resolver)); |
+ return promise; |
} |
ScriptPromise Geofencing::getRegisteredRegions(ScriptState* scriptState) const |
{ |
- return ScriptPromise::rejectWithDOMException(scriptState, DOMException::create(NotSupportedError)); |
+ WebGeofencingProvider* provider = Platform::current()->geofencingProvider(); |
+ if (!provider) { |
+ return ScriptPromise::rejectWithDOMException(scriptState, DOMException::create(NotSupportedError)); |
+ } |
+ |
+ RefPtr<ScriptPromiseResolver> resolver = ScriptPromiseResolver::create(scriptState); |
+ ScriptPromise promise = resolver->promise(); |
+ provider->getRegisteredRegions(new CallbackPromiseAdapter<RegionArray, GeofencingError>(resolver)); |
+ return promise; |
} |
} // namespace blink |