1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151
|
// Copyright 2013 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#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/WebServiceWorkerClientFocusCallback.h"
#include "third_party/WebKit/public/platform/WebServiceWorkerClientsInfo.h"
#include "third_party/WebKit/public/platform/WebServiceWorkerEventResult.h"
#include "third_party/WebKit/public/platform/WebServiceWorkerSkipWaitingCallbacks.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 {
class ServiceWorkerScriptContext;
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.
// This should implement WebEmbeddedWorkerContextClient
// or sort of it (which doesn't exist yet) rather than
// WebServiceWorkerContextClient if we want to separate them more cleanly,
// or ServiceWorkerScriptContext should be merged into this class
// if we consider EW == SW script context.
class EmbeddedWorkerContextClient
: public blink::WebServiceWorkerContextClient {
public:
// Returns a thread-specific client instance. This does NOT create a
// new instance.
static EmbeddedWorkerContextClient* ThreadSpecificInstance();
EmbeddedWorkerContextClient(int embedded_worker_id,
int64 service_worker_version_id,
const GURL& service_worker_scope,
const GURL& script_url,
int worker_devtools_agent_route_id);
virtual ~EmbeddedWorkerContextClient();
bool OnMessageReceived(const IPC::Message& msg);
void Send(IPC::Message* message);
// 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 workerReadyForInspection();
virtual void workerContextFailedToStart();
virtual void workerContextStarted(blink::WebServiceWorkerContextProxy* proxy);
virtual void didEvaluateWorkerScript(bool success);
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 didHandleNotificationClickEvent(
int request_id,
blink::WebServiceWorkerEventResult result);
virtual void didHandlePushEvent(int request_id,
blink::WebServiceWorkerEventResult result);
virtual void didHandleSyncEvent(int request_id);
virtual void didHandleCrossOriginConnectEvent(int request_id,
bool accept_connection);
virtual blink::WebServiceWorkerNetworkProvider*
createServiceWorkerNetworkProvider(blink::WebDataSource* data_source);
virtual void postMessageToClient(
int client_id,
const blink::WebString& message,
blink::WebMessagePortChannelArray* channels);
virtual void postMessageToCrossOriginClient(
const blink::WebCrossOriginServiceWorkerClient& client,
const blink::WebString& message,
blink::WebMessagePortChannelArray* channels);
virtual void focus(int client_id,
blink::WebServiceWorkerClientFocusCallback*);
virtual void skipWaiting(
blink::WebServiceWorkerSkipWaitingCallbacks* callbacks);
// 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_.get();
}
ThreadSafeSender* thread_safe_sender() { return sender_.get(); }
private:
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_RENDERER_SERVICE_WORKER_EMBEDDED_WORKER_CONTEXT_CLIENT_H_
|