Chromium Code Reviews| Index: content/browser/push_messaging_message_filter.cc |
| diff --git a/content/browser/push_messaging_message_filter.cc b/content/browser/push_messaging_message_filter.cc |
| index 01193c14a34d554fc5024f06ff7a5475a4bcedc0..890e49f70a77d058a383942f506a93e56e0f5348 100644 |
| --- a/content/browser/push_messaging_message_filter.cc |
| +++ b/content/browser/push_messaging_message_filter.cc |
| @@ -14,6 +14,7 @@ |
| #include "content/public/browser/browser_context.h" |
| #include "content/public/browser/browser_thread.h" |
| #include "content/public/browser/push_messaging_service.h" |
| +#include "third_party/WebKit/public/platform/WebPushPermissionCallback.h" |
| namespace content { |
| @@ -34,11 +35,16 @@ bool PushMessagingMessageFilter::OnMessageReceived( |
| bool handled = true; |
| IPC_BEGIN_MESSAGE_MAP(PushMessagingMessageFilter, message) |
| IPC_MESSAGE_HANDLER(PushMessagingHostMsg_Register, OnRegister) |
| + IPC_MESSAGE_HANDLER(PushMessagingHostMsg_PermissionStatus, |
| + OnPermissionStatus) |
| IPC_MESSAGE_UNHANDLED(handled = false) |
| IPC_END_MESSAGE_MAP() |
| return handled; |
| } |
| +// TODO(miguelg) No need to post to the UI thread manually |
|
Michael van Ouwerkerk
2014/10/20 16:30:08
This is wrong, please delete it. ServiceWorkerCont
Miguel Garcia
2014/10/22 16:35:27
Done. Thanks for the offline explanation on why.
|
| +// we can use BrowserMessageFilter::OverrideThreadForMessage() |
| +// instead. |
| void PushMessagingMessageFilter::OnRegister(int render_frame_id, |
| int callbacks_id, |
| const std::string& sender_id, |
| @@ -69,6 +75,26 @@ void PushMessagingMessageFilter::OnRegister(int render_frame_id, |
| service_worker_host->active_version()->registration_id())); |
| } |
| +void PushMessagingMessageFilter::OnPermissionStatus( |
| + int render_frame_id, |
| + int service_worker_provider_id, |
| + int permission_callback_id) { |
| + ServiceWorkerProviderHost* service_worker_host = |
|
Michael van Ouwerkerk
2014/10/20 16:30:08
Add this as the first line in this method:
DCHECK_
Miguel Garcia
2014/10/22 16:35:27
Done.
|
| + service_worker_context_->context()->GetProviderHost( |
| + render_process_id_, service_worker_provider_id); |
| + |
| + if (service_worker_host && service_worker_host->active_version()) { |
| + BrowserThread::PostTask( |
| + BrowserThread::UI, |
| + FROM_HERE, |
| + base::Bind(&PushMessagingMessageFilter::DoPermissionStatus, |
| + weak_factory_.GetWeakPtr(), |
| + service_worker_host->active_version()->scope().GetOrigin(), |
| + render_frame_id, |
| + permission_callback_id)); |
| + } |
| +} |
| + |
| void PushMessagingMessageFilter::DoRegister( |
| int render_frame_id, |
| int callbacks_id, |
| @@ -112,6 +138,17 @@ void PushMessagingMessageFilter::DidRegister( |
| } |
| } |
| +void PushMessagingMessageFilter::DoPermissionStatus( |
| + const GURL& requesting_origin, |
| + int render_frame_id, int callback_id) { |
| + blink::WebPushPermissionCallback::PushPermissionStatus permission_value = |
|
Michael van Ouwerkerk
2014/10/20 16:30:08
DCHECK_CURRENTLY_ON(BrowserThread::UI);
Miguel Garcia
2014/10/22 16:35:27
Done.
|
| + service()->PermissionStatus(requesting_origin, render_process_id_, |
| + render_frame_id); |
| + |
| + Send(new PushMessagingMsg_PermissionStatusResult( |
| + render_frame_id, callback_id, permission_value)); |
| +} |
| + |
| PushMessagingService* PushMessagingMessageFilter::service() { |
| if (!service_) { |
| RenderProcessHost* process_host = |