Upstream version 7.36.149.0
[platform/framework/web/crosswalk.git] / src / content / renderer / service_worker / embedded_worker_context_client.h
index 6e6d3d8..7d18ec5 100644 (file)
@@ -10,6 +10,9 @@
 #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"
 
@@ -18,6 +21,10 @@ class MessageLoopProxy;
 class TaskRunner;
 }
 
+namespace blink {
+class WebDataSource;
+}
+
 namespace content {
 
 class ServiceWorkerScriptContext;
@@ -25,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.
@@ -42,24 +50,53 @@ 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(int request_id, const IPC::Message& message);
+  void Send(IPC::Message* message);
+
+  // TODO(kinuko): Deprecate this.
+  void SendReplyToBrowser(int request_id, const IPC::Message& message);
 
   // WebServiceWorkerContextClient overrides, some of them are just dispatched
   // on to script_context_.
+  virtual blink::WebURL scope() const;
+  virtual void getClients(blink::WebServiceWorkerClientsCallbacks*);
   virtual void workerContextFailedToStart();
   virtual void workerContextStarted(blink::WebServiceWorkerContextProxy* proxy);
+  virtual void willDestroyWorkerContext();
   virtual void workerContextDestroyed();
-  virtual void didHandleInstallEvent(int request_id);
+  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.
 
@@ -67,17 +104,19 @@ class EmbeddedWorkerContextClient
   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,
-                             int request_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_;