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
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#include "ServiceWorkerImpl.h"
#include "ServiceWorkerInfo.h"
#include "ServiceWorkerRegistrationInfo.h"
namespace mozilla {
namespace dom {
ServiceWorkerImpl::~ServiceWorkerImpl() { MOZ_DIAGNOSTIC_ASSERT(!mOuter); }
void ServiceWorkerImpl::AddServiceWorker(ServiceWorker* aWorker) {
MOZ_DIAGNOSTIC_ASSERT(!mOuter);
MOZ_DIAGNOSTIC_ASSERT(aWorker);
mOuter = aWorker;
}
void ServiceWorkerImpl::RemoveServiceWorker(ServiceWorker* aWorker) {
MOZ_DIAGNOSTIC_ASSERT(mOuter);
MOZ_DIAGNOSTIC_ASSERT(mOuter == aWorker);
mOuter = nullptr;
}
void ServiceWorkerImpl::GetRegistration(
ServiceWorkerRegistrationCallback&& aSuccessCB,
ServiceWorkerFailureCallback&& aFailureCB) {
// While we could immediate call success with our registration descriptor
// we instead queue a runnable to do this. This ensures that
// GetRegistration() is always async to match how the IPC implementation will
// work. It also ensure that if any events are triggered from providing the
// registration that they are fired from a runnable on the correct global's
// event target.
if (!mOuter) {
aFailureCB(CopyableErrorResult(NS_ERROR_DOM_INVALID_STATE_ERR));
return;
}
nsIGlobalObject* global = mOuter->GetParentObject();
if (!global) {
aFailureCB(CopyableErrorResult(NS_ERROR_DOM_INVALID_STATE_ERR));
return;
}
nsCOMPtr<nsIRunnable> r = NS_NewRunnableFunction(
"ServiceWorkerImpl::GetRegistration",
[reg = mReg, successCB = std::move(aSuccessCB)]() mutable {
successCB(reg->Descriptor());
});
nsresult rv = global->EventTargetFor(TaskCategory::Other)
->Dispatch(r.forget(), NS_DISPATCH_NORMAL);
if (NS_FAILED(rv)) {
aFailureCB(CopyableErrorResult(rv));
return;
}
}
void ServiceWorkerImpl::PostMessage(RefPtr<ServiceWorkerCloneData>&& aData,
const ClientInfo& aClientInfo,
const ClientState& aClientState) {
mInfo->PostMessage(std::move(aData), aClientInfo, aClientState);
}
ServiceWorkerImpl::ServiceWorkerImpl(ServiceWorkerInfo* aInfo,
ServiceWorkerRegistrationInfo* aReg)
: mInfo(aInfo), mReg(aReg), mOuter(nullptr) {
MOZ_DIAGNOSTIC_ASSERT(mInfo);
MOZ_DIAGNOSTIC_ASSERT(mReg);
}
} // namespace dom
} // namespace mozilla
|