Chromium Code Reviews| Index: third_party/WebKit/Source/modules/serviceworkers/PaymentRequestRespondWithObserver.cpp |
| diff --git a/third_party/WebKit/Source/modules/serviceworkers/PaymentRequestRespondWithObserver.cpp b/third_party/WebKit/Source/modules/serviceworkers/PaymentRequestRespondWithObserver.cpp |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..7623e0f7e67e3fdb23eedd83bae8a78dfaa068ad |
| --- /dev/null |
| +++ b/third_party/WebKit/Source/modules/serviceworkers/PaymentRequestRespondWithObserver.cpp |
| @@ -0,0 +1,136 @@ |
| +// Copyright 2017 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "modules/serviceworkers/PaymentRequestRespondWithObserver.h" |
| + |
| +#include <v8.h> |
| +#include "bindings/core/v8/ScriptValue.h" |
| +#include "bindings/core/v8/V8Binding.h" |
| +#include "bindings/modules/v8/V8PaymentAppResponse.h" |
| +#include "core/dom/ExecutionContext.h" |
| +#include "core/inspector/ConsoleMessage.h" |
| +#include "modules/payments/PaymentAppResponse.h" |
| +#include "modules/serviceworkers/ServiceWorkerGlobalScopeClient.h" |
| +#include "modules/serviceworkers/WaitUntilObserver.h" |
| +#include "public/platform/modules/payments/WebPaymentAppResponse.h" |
| + |
| +namespace blink { |
| +namespace { |
| + |
| +// Returns the error message to let the developer know about the reason of the |
| +// unusual failures. |
| +const String getMessageForResponseError(WebServiceWorkerResponseError error) { |
| + String errorMessage = |
| + "The PaymentRequestEvent resulted in a network error response: "; |
| + switch (error) { |
| + case WebServiceWorkerResponseErrorPromiseRejected: |
| + errorMessage = errorMessage + "the promise was rejected."; |
| + break; |
| + case WebServiceWorkerResponseErrorDefaultPrevented: |
| + errorMessage = |
| + errorMessage + |
| + "preventDefault() was called without calling respondWith()."; |
| + break; |
| + case WebServiceWorkerResponseErrorNoV8Instance: |
| + errorMessage = errorMessage + |
| + "an object that was not a PaymentResponse was passed to " |
| + "respondWith()."; |
| + break; |
| + case WebServiceWorkerResponseErrorResponseTypeError: |
| + errorMessage = errorMessage + |
| + "the promise was resolved with an error response object."; |
| + break; |
| + case WebServiceWorkerResponseErrorUnknown: |
| + default: |
|
nhiroki
2017/03/08 02:28:16
I'd recommend not to use 'default' for WebServiceW
zino
2017/03/10 17:57:52
Done.
|
| + errorMessage = errorMessage + "an unexpected error occurred."; |
| + break; |
| + } |
| + return errorMessage; |
| +} |
| + |
| +} // namespace |
| + |
| +PaymentRequestRespondWithObserver::~PaymentRequestRespondWithObserver() {} |
| + |
| +PaymentRequestRespondWithObserver* PaymentRequestRespondWithObserver::create( |
| + ExecutionContext* context, |
| + int eventID, |
| + WaitUntilObserver* observer) { |
| + return new PaymentRequestRespondWithObserver(context, eventID, observer); |
| +} |
| + |
| +void PaymentRequestRespondWithObserver::didDispatchEvent( |
| + DispatchEventResult dispatchResult) { |
| + DCHECK(getExecutionContext()); |
| + if (m_state != Initial) |
| + return; |
| + |
| + if (dispatchResult != DispatchEventResult::NotCanceled) { |
| + m_observer->incrementPendingActivity(); |
| + responseWasRejected(WebServiceWorkerResponseErrorDefaultPrevented); |
| + return; |
| + } |
| + |
| + WebPaymentAppResponse webData; |
| + ServiceWorkerGlobalScopeClient::from(getExecutionContext()) |
| + ->respondToPaymentRequestEvent(m_eventID, webData, m_eventDispatchTime); |
| + m_state = Done; |
| + m_observer.clear(); |
| +} |
| + |
| +void PaymentRequestRespondWithObserver::responseWasRejected( |
| + WebServiceWorkerResponseError error) { |
| + DCHECK(getExecutionContext()); |
| + |
| + getExecutionContext()->addConsoleMessage(ConsoleMessage::create( |
| + JSMessageSource, WarningMessageLevel, getMessageForResponseError(error))); |
| + |
| + WebPaymentAppResponse webData; |
| + ServiceWorkerGlobalScopeClient::from(getExecutionContext()) |
| + ->respondToPaymentRequestEvent(m_eventID, webData, m_eventDispatchTime); |
| + RespondWithObserver::responseWasRejected(error); |
| +} |
| + |
| +void PaymentRequestRespondWithObserver::responseWasFulfilled( |
| + const ScriptValue& value) { |
| + DCHECK(getExecutionContext()); |
| + |
| + PaymentAppResponse response; |
| + DummyExceptionStateForTesting exceptionState; |
|
nhiroki
2017/03/08 02:28:16
Using a dummy exception state looks strange. I don
zino
2017/03/10 17:57:52
Done.
|
| + V8PaymentAppResponse::toImpl(toIsolate(getExecutionContext()), |
| + value.v8Value(), response, exceptionState); |
| + |
| + if (exceptionState.hadException()) { |
| + responseWasRejected(WebServiceWorkerResponseErrorNoV8Instance); |
| + return; |
| + } |
| + |
| + WebPaymentAppResponse webData; |
| + webData.methodName = WebString(AtomicString(response.methodName())); |
| + |
| + v8::Local<v8::String> detailsValue; |
| + if (!v8::JSON::Stringify(response.details().context(), |
| + response.details().v8Value().As<v8::Object>()) |
| + .ToLocal(&detailsValue)) { |
| + responseWasRejected(WebServiceWorkerResponseErrorUnknown); |
| + return; |
| + } |
| + webData.stringifiedDetails = WebString(AtomicString( |
| + v8StringToWebCoreString<String>(detailsValue, DoNotExternalize))); |
| + ServiceWorkerGlobalScopeClient::from(getExecutionContext()) |
| + ->respondToPaymentRequestEvent(m_eventID, webData, m_eventDispatchTime); |
| + RespondWithObserver::responseWasFulfilled(value); |
| +} |
| + |
| +PaymentRequestRespondWithObserver::PaymentRequestRespondWithObserver( |
| + ExecutionContext* context, |
| + int eventID, |
| + WaitUntilObserver* observer) |
| + : RespondWithObserver(context, eventID, observer) {} |
| + |
| +DEFINE_TRACE(PaymentRequestRespondWithObserver) { |
| + RespondWithObserver::trace(visitor); |
| +} |
| + |
| +} // namespace blink |