blob: 4cc9627328f3d6ebd812131b7fe63e214f3735a9 [file] [log] [blame]
/*
* Copyright (C) 2009 Google Inc. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are
* met:
*
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above
* copyright notice, this list of conditions and the following disclaimer
* in the documentation and/or other materials provided with the
* distribution.
* * Neither the name of Google Inc. nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef THIRD_PARTY_BLINK_PUBLIC_WEB_WEB_SHARED_WORKER_CLIENT_H_
#define THIRD_PARTY_BLINK_PUBLIC_WEB_WEB_SHARED_WORKER_CLIENT_H_
#include "third_party/blink/public/platform/web_content_settings_client.h"
#include "third_party/blink/public/platform/web_feature.mojom-shared.h"
#include "third_party/blink/public/platform/web_worker_fetch_context.h"
namespace blink {
class WebApplicationCacheHost;
class WebApplicationCacheHostClient;
class WebNotificationPresenter;
class WebServiceWorkerNetworkProvider;
// Provides an interface back to the in-page script object for a worker.
// All functions are expected to be called back on the thread that created
// the Worker object, unless noted.
//
// An instance of this class must outlive WebSharedWorker (i.e. must be kept
// alive until WorkerScriptLoadFailed() or WorkerContextDestroyed() is called).
class WebSharedWorkerClient {
public:
virtual void CountFeature(mojom::WebFeature) = 0;
virtual void WorkerContextClosed() = 0;
virtual void WorkerContextDestroyed() = 0;
virtual void WorkerReadyForInspection() {}
virtual void WorkerScriptLoaded() = 0;
virtual void WorkerScriptLoadFailed() = 0;
virtual void SelectAppCacheID(long long) = 0;
// Returns the notification presenter for this worker context. Pointer
// is owned by the object implementing WebSharedWorkerClient.
virtual WebNotificationPresenter* NotificationPresenter() = 0;
// Called on the main webkit thread in the worker process during
// initialization.
virtual std::unique_ptr<WebApplicationCacheHost> CreateApplicationCacheHost(
WebApplicationCacheHostClient*) = 0;
// Called on the main thread during initialization, before requesting the main
// script resource. Creates the ServiceWorkerNetworkProvider which is used for
// script loading (i.e., the main script and importScripts). Other requests
// (e.g., fetch and XHR) go through WebWorkerFetchContext.
virtual std::unique_ptr<WebServiceWorkerNetworkProvider>
CreateServiceWorkerNetworkProvider() = 0;
// Called on the main thread during initialization, after the main script
// resource finished loading. Creates a new WebWorkerFetchContext for the
// shared worker. This is passed to the worker thread and used for non-script
// loading requests from the shared worker (e.g., fetch and XHR). Requests for
// script loading (i.e., the main script and importScripts) go through
// WebServiceWorkerNetworkProvider.
virtual scoped_refptr<WebWorkerFetchContext> CreateWorkerFetchContext(
WebServiceWorkerNetworkProvider*) = 0;
// Called on the main thread during initialization. The browser process is
// expected to send a SetController IPC before sending the script response if
// appropriate, but there is no ordering guarantee of the messages on the
// renderer. This waits for the SetController IPC to be received if it was
// sent.
virtual void WaitForServiceWorkerControllerInfo(
blink::WebServiceWorkerNetworkProvider* web_network_provider,
base::OnceClosure callback) = 0;
};
} // namespace blink
#endif