Index: content/browser/push_messaging/push_messaging_router.cc |
diff --git a/content/browser/push_messaging/push_messaging_router.cc b/content/browser/push_messaging/push_messaging_router.cc |
index bc95216ad07698514323caf241f6a1542273660d..822bc299687480fb5629ff99df90d5117572d1fa 100644 |
--- a/content/browser/push_messaging/push_messaging_router.cc |
+++ b/content/browser/push_messaging/push_messaging_router.cc |
@@ -10,6 +10,7 @@ |
#include "content/browser/service_worker/service_worker_context_wrapper.h" |
#include "content/browser/service_worker/service_worker_registration.h" |
#include "content/browser/service_worker/service_worker_storage.h" |
+#include "content/common/service_worker/service_worker_messages.h" |
#include "content/common/service_worker/service_worker_status_code.h" |
#include "content/public/browser/browser_context.h" |
#include "content/public/browser/browser_thread.h" |
@@ -27,6 +28,21 @@ void RunDeliverCallback( |
base::Bind(deliver_message_callback, delivery_status)); |
} |
+void OnPushEventResponse(scoped_refptr<ServiceWorkerVersion> service_worker, |
johnme
2016/01/18 19:06:19
[see comment in .h first]
Please add DCHECK_CURRE
Marijn Kruisselbrink
2016/01/20 01:06:31
Done
|
+ base::Callback<void(ServiceWorkerStatusCode)> callback, |
+ int request_id, |
+ blink::WebServiceWorkerEventResult result) { |
+ TRACE_EVENT1("ServiceWorker", "PushMessagingRouter::OnPushEventResponse", |
+ "Request id", request_id); |
+ |
+ service_worker->FinishRequest(request_id); |
johnme
2016/01/18 19:06:19
[see comment in .h first]
Please apply equivalent
Marijn Kruisselbrink
2016/01/20 01:06:31
Done
|
+ |
+ ServiceWorkerStatusCode status = SERVICE_WORKER_OK; |
+ if (result == blink::WebServiceWorkerEventResultRejected) |
+ status = SERVICE_WORKER_ERROR_EVENT_WAITUNTIL_REJECTED; |
+ callback.Run(status); |
+} |
+ |
} // namespace |
// static |
@@ -50,6 +66,26 @@ void PushMessagingRouter::DeliverMessage( |
} |
// static |
+void PushMessagingRouter::DeliverMessageToWorker( |
johnme
2016/01/18 19:06:19
[see comment in .h first]
Nit: please move this b
Marijn Kruisselbrink
2016/01/20 01:06:31
That would go against the chromium coding style: "
|
+ const scoped_refptr<ServiceWorkerVersion>& service_worker, |
+ const std::string& data, |
+ const base::Callback<void(ServiceWorkerStatusCode)>& callback) { |
+ DCHECK_CURRENTLY_ON(BrowserThread::IO); |
+ if (service_worker->running_status() != ServiceWorkerVersion::RUNNING) { |
johnme
2016/01/18 19:06:19
[see comment in .h first]
Nit: In https://coderev
Marijn Kruisselbrink
2016/01/20 01:06:31
The reason for the difference was to keep the chan
|
+ service_worker->RunAfterStartWorker( |
+ callback, base::Bind(&PushMessagingRouter::DeliverMessageToWorker, |
+ service_worker, data, callback)); |
+ return; |
+ } |
+ |
+ int request_id = service_worker->StartRequest( |
+ ServiceWorkerMetrics::EventType::PUSH, callback); |
+ service_worker->DispatchEvent<ServiceWorkerHostMsg_PushEventFinished>( |
+ request_id, ServiceWorkerMsg_PushEvent(request_id, data), |
+ base::Bind(&OnPushEventResponse, service_worker, callback)); |
+} |
+ |
+// static |
void PushMessagingRouter::FindServiceWorkerRegistration( |
const GURL& origin, |
int64_t service_worker_registration_id, |
@@ -90,8 +126,7 @@ void PushMessagingRouter::FindServiceWorkerRegistrationCallback( |
base::Callback<void(ServiceWorkerStatusCode)> dispatch_event_callback = |
base::Bind(&PushMessagingRouter::DeliverMessageEnd, |
deliver_message_callback, service_worker_registration); |
- |
- version->DispatchPushEvent(dispatch_event_callback, data); |
+ DeliverMessageToWorker(version, data, dispatch_event_callback); |
} |
// static |