OLD | NEW |
(Empty) | |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. |
| 4 |
| 5 #include "extensions/renderer/worker_thread_dispatcher.h" |
| 6 |
| 7 #include "base/threading/thread_local.h" |
| 8 #include "base/values.h" |
| 9 #include "content/public/child/worker_thread.h" |
| 10 #include "content/public/renderer/render_thread.h" |
| 11 #include "extensions/common/extension_messages.h" |
| 12 #include "extensions/renderer/service_worker_data.h" |
| 13 |
| 14 namespace extensions { |
| 15 |
| 16 namespace { |
| 17 |
| 18 base::LazyInstance<WorkerThreadDispatcher> g_instance = |
| 19 LAZY_INSTANCE_INITIALIZER; |
| 20 base::LazyInstance<base::ThreadLocalPointer<extensions::ServiceWorkerData>> |
| 21 g_data_tls = LAZY_INSTANCE_INITIALIZER; |
| 22 |
| 23 void OnResponseOnWorkerThread(int request_id, |
| 24 bool succeeded, |
| 25 const scoped_ptr<base::ListValue>& response, |
| 26 const std::string& error) { |
| 27 WorkerThreadDispatcher::GetRequestSender()->HandleResponse( |
| 28 request_id, succeeded, *response, error); |
| 29 } |
| 30 |
| 31 } // namespace |
| 32 |
| 33 WorkerThreadDispatcher::WorkerThreadDispatcher() {} |
| 34 WorkerThreadDispatcher::~WorkerThreadDispatcher() {} |
| 35 |
| 36 WorkerThreadDispatcher* WorkerThreadDispatcher::Get() { |
| 37 return g_instance.Pointer(); |
| 38 } |
| 39 |
| 40 void WorkerThreadDispatcher::Init(content::RenderThread* render_thread) { |
| 41 DCHECK(render_thread); |
| 42 DCHECK_EQ(content::RenderThread::Get(), render_thread); |
| 43 DCHECK(!message_filter_); |
| 44 message_filter_ = render_thread->GetSyncMessageFilter(); |
| 45 render_thread->AddObserver(this); |
| 46 } |
| 47 |
| 48 V8SchemaRegistry* WorkerThreadDispatcher::GetV8SchemaRegistry() { |
| 49 ServiceWorkerData* data = g_data_tls.Pointer()->Get(); |
| 50 DCHECK(data); |
| 51 return data->v8_schema_registry(); |
| 52 } |
| 53 |
| 54 // static |
| 55 RequestSender* WorkerThreadDispatcher::GetRequestSender() { |
| 56 ServiceWorkerData* data = g_data_tls.Pointer()->Get(); |
| 57 DCHECK(data); |
| 58 return data->request_sender(); |
| 59 } |
| 60 |
| 61 bool WorkerThreadDispatcher::OnControlMessageReceived( |
| 62 const IPC::Message& message) { |
| 63 bool handled = true; |
| 64 IPC_BEGIN_MESSAGE_MAP(WorkerThreadDispatcher, message) |
| 65 IPC_MESSAGE_HANDLER(ExtensionMsg_ResponseWorker, OnResponseWorker) |
| 66 IPC_MESSAGE_UNHANDLED(handled = false) |
| 67 IPC_END_MESSAGE_MAP() |
| 68 return handled; |
| 69 } |
| 70 |
| 71 bool WorkerThreadDispatcher::Send(IPC::Message* message) { |
| 72 return message_filter_->Send(message); |
| 73 } |
| 74 |
| 75 void WorkerThreadDispatcher::OnResponseWorker(int worker_thread_id, |
| 76 int request_id, |
| 77 bool succeeded, |
| 78 const base::ListValue& response, |
| 79 const std::string& error) { |
| 80 content::WorkerThread::PostTask( |
| 81 worker_thread_id, |
| 82 base::Bind(&OnResponseOnWorkerThread, request_id, succeeded, |
| 83 // TODO(lazyboy): Can we avoid CreateDeepCopy()? |
| 84 base::Passed(response.CreateDeepCopy()), error)); |
| 85 } |
| 86 |
| 87 void WorkerThreadDispatcher::AddWorkerData(int embedded_worker_id) { |
| 88 ServiceWorkerData* data = g_data_tls.Pointer()->Get(); |
| 89 if (!data) { |
| 90 ServiceWorkerData* new_data = |
| 91 new ServiceWorkerData(this, embedded_worker_id); |
| 92 g_data_tls.Pointer()->Set(new_data); |
| 93 } |
| 94 } |
| 95 |
| 96 void WorkerThreadDispatcher::RemoveWorkerData(int embedded_worker_id) { |
| 97 ServiceWorkerData* data = g_data_tls.Pointer()->Get(); |
| 98 if (data) { |
| 99 DCHECK_EQ(embedded_worker_id, data->embedded_worker_id()); |
| 100 delete data; |
| 101 g_data_tls.Pointer()->Set(nullptr); |
| 102 } |
| 103 } |
| 104 |
| 105 } // namespace extensions |
OLD | NEW |