Upstream version 9.38.198.0
[platform/framework/web/crosswalk.git] / src / content / renderer / service_worker / embedded_worker_context_client.h
index 68e1aad..bf261fc 100644 (file)
@@ -2,17 +2,27 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#ifndef CONTENT_CHILD_SERVICE_WORKER_EMBEDDED_WORKER_CLIENT_H_
-#define CONTENT_CHILD_SERVICE_WORKER_EMBEDDED_WORKER_CLIENT_H_
+#ifndef CONTENT_RENDERER_SERVICE_WORKER_EMBEDDED_WORKER_CONTEXT_CLIENT_H_
+#define CONTENT_RENDERER_SERVICE_WORKER_EMBEDDED_WORKER_CONTEXT_CLIENT_H_
 
 #include "base/memory/ref_counted.h"
+#include "base/memory/weak_ptr.h"
 #include "base/strings/string16.h"
+#include "content/common/service_worker/service_worker_types.h"
 #include "ipc/ipc_listener.h"
+#include "third_party/WebKit/public/platform/WebServiceWorkerClientsInfo.h"
+#include "third_party/WebKit/public/platform/WebServiceWorkerEventResult.h"
+#include "third_party/WebKit/public/platform/WebURL.h"
 #include "third_party/WebKit/public/web/WebServiceWorkerContextClient.h"
 #include "url/gurl.h"
 
 namespace base {
 class MessageLoopProxy;
+class TaskRunner;
+}
+
+namespace blink {
+class WebDataSource;
 }
 
 namespace content {
@@ -22,6 +32,7 @@ class ThreadSafeSender;
 
 // This class provides access to/from an embedded worker's WorkerGlobalScope.
 // All methods other than the constructor (it's created on the main thread)
+// and createServiceWorkerNetworkProvider (also called on the main thread)
 // are called on the worker thread.
 //
 // TODO(kinuko): Currently EW/SW separation is made a little hazily.
@@ -39,39 +50,83 @@ class EmbeddedWorkerContextClient
 
   EmbeddedWorkerContextClient(int embedded_worker_id,
                               int64 service_worker_version_id,
-                              const GURL& script_url);
+                              const GURL& service_worker_scope,
+                              const GURL& script_url,
+                              int worker_devtools_agent_route_id);
 
   virtual ~EmbeddedWorkerContextClient();
 
   bool OnMessageReceived(const IPC::Message& msg);
 
-  void SendMessageToBrowser(const IPC::Message& message);
+  void Send(IPC::Message* message);
 
-  // WebServiceWorkerContextClient overrides.
+  // WebServiceWorkerContextClient overrides, some of them are just dispatched
+  // on to script_context_.
+  virtual blink::WebURL scope() const;
+  virtual blink::WebServiceWorkerCacheStorage* cacheStorage();
+  virtual void didPauseAfterDownload();
+  virtual void getClients(blink::WebServiceWorkerClientsCallbacks*);
   virtual void workerContextFailedToStart();
   virtual void workerContextStarted(blink::WebServiceWorkerContextProxy* proxy);
+  virtual void willDestroyWorkerContext();
   virtual void workerContextDestroyed();
+  virtual void reportException(const blink::WebString& error_message,
+                               int line_number,
+                               int column_number,
+                               const blink::WebString& source_url);
+  virtual void reportConsoleMessage(int source,
+                                    int level,
+                                    const blink::WebString& message,
+                                    int line_number,
+                                    const blink::WebString& source_url);
+  virtual void dispatchDevToolsMessage(const blink::WebString&);
+  virtual void saveDevToolsAgentState(const blink::WebString&);
+  virtual void didHandleActivateEvent(int request_id,
+                                      blink::WebServiceWorkerEventResult);
+  virtual void didHandleInstallEvent(int request_id,
+                                     blink::WebServiceWorkerEventResult result);
+  virtual void didHandleFetchEvent(int request_id);
+  virtual void didHandleFetchEvent(
+      int request_id,
+      const blink::WebServiceWorkerResponse& response);
+  virtual void didHandleSyncEvent(int request_id);
+  virtual blink::WebServiceWorkerNetworkProvider*
+      createServiceWorkerNetworkProvider(blink::WebDataSource* data_source);
+  virtual void postMessageToClient(
+      int client_id,
+      const blink::WebString& message,
+      blink::WebMessagePortChannelArray* channels);
 
   // TODO: Implement DevTools related method overrides.
 
   int embedded_worker_id() const { return embedded_worker_id_; }
+  base::MessageLoopProxy* main_thread_proxy() const {
+    return main_thread_proxy_;
+  }
+  ThreadSafeSender* thread_safe_sender() { return sender_; }
 
  private:
-  void OnSendMessageToWorker(int thread_id,
-                             int embedded_worker_id,
-                             const IPC::Message& message);
+  void OnMessageToWorker(int thread_id,
+                         int embedded_worker_id,
+                         const IPC::Message& message);
+  void SendWorkerStarted();
 
   const int embedded_worker_id_;
   const int64 service_worker_version_id_;
+  const GURL service_worker_scope_;
   const GURL script_url_;
+  const int worker_devtools_agent_route_id_;
   scoped_refptr<ThreadSafeSender> sender_;
   scoped_refptr<base::MessageLoopProxy> main_thread_proxy_;
+  scoped_refptr<base::TaskRunner> worker_task_runner_;
 
   scoped_ptr<ServiceWorkerScriptContext> script_context_;
 
+  base::WeakPtrFactory<EmbeddedWorkerContextClient> weak_factory_;
+
   DISALLOW_COPY_AND_ASSIGN(EmbeddedWorkerContextClient);
 };
 
 }  // namespace content
 
-#endif  // CONTENT_CHILD_SERVICE_WORKER_EMBEDDED_WORKER_CLIENT_H_
+#endif  // CONTENT_RENDERER_SERVICE_WORKER_EMBEDDED_WORKER_CONTEXT_CLIENT_H_