#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"
class TaskRunner;
}
+namespace blink {
+class WebDataSource;
+}
+
namespace content {
class ServiceWorkerScriptContext;
// 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.
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.
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_;