#pragma once
#if ENABLE(SERVICE_WORKER)
#include "ActiveDOMObject.h"
#include "ContextDestructionObserver.h"
#include "EventTarget.h"
#include "ServiceWorkerData.h"
#include "URL.h"
#include <JavaScriptCore/Strong.h>
#include <wtf/RefCounted.h>
namespace JSC {
class JSValue;
}
namespace WebCore {
class Frame;
class ServiceWorker final : public RefCounted<ServiceWorker>, public EventTargetWithInlineData, public ActiveDOMObject {
public:
using State = ServiceWorkerState;
static Ref<ServiceWorker> getOrCreate(ScriptExecutionContext&, ServiceWorkerData&&);
virtual ~ServiceWorker();
const URL& scriptURL() const { return m_data.scriptURL; }
State state() const { return m_data.state; }
void scheduleTaskToUpdateState(State);
ExceptionOr<void> postMessage(ScriptExecutionContext&, JSC::JSValue message, Vector<JSC::Strong<JSC::JSObject>>&&);
ServiceWorkerIdentifier identifier() const { return m_data.identifier; }
ServiceWorkerRegistrationIdentifier registrationIdentifier() const { return m_data.registrationIdentifier; }
using RefCounted::ref;
using RefCounted::deref;
private:
ServiceWorker(ScriptExecutionContext&, ServiceWorkerData&&);
void updatePendingActivityForEventDispatch();
EventTargetInterface eventTargetInterface() const final;
ScriptExecutionContext* scriptExecutionContext() const final;
void refEventTarget() final { ref(); }
void derefEventTarget() final { deref(); }
const char* activeDOMObjectName() const final;
bool canSuspendForDocumentSuspension() const final;
void stop() final;
bool isAlwaysOnLoggingAllowed() const;
ServiceWorkerData m_data;
bool m_isStopped { false };
RefPtr<PendingActivity<ServiceWorker>> m_pendingActivityForEventDispatch;
};
}
#endif // ENABLE(SERVICE_WORKER)