mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-11-24 13:21:05 +00:00
f5b7f71fb3
This patch implements the parent process' part of NavigationPreload API. After receiving the IPC, using the corresponding ServiceWorkerRegistrationProxy to send data to the main thread, then saving the NavigationPreload data on ServiceWorkerRegistrationInfo. Depends on D116916 Differential Revision: https://phabricator.services.mozilla.com/D116917
155 lines
4.2 KiB
C++
155 lines
4.2 KiB
C++
/* -*- 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 "ServiceWorkerRegistrationParent.h"
|
|
|
|
#include <utility>
|
|
|
|
#include "ServiceWorkerRegistrationProxy.h"
|
|
|
|
namespace mozilla {
|
|
namespace dom {
|
|
|
|
using mozilla::ipc::IPCResult;
|
|
|
|
void ServiceWorkerRegistrationParent::ActorDestroy(ActorDestroyReason aReason) {
|
|
if (mProxy) {
|
|
mProxy->RevokeActor(this);
|
|
mProxy = nullptr;
|
|
}
|
|
}
|
|
|
|
IPCResult ServiceWorkerRegistrationParent::RecvTeardown() {
|
|
MaybeSendDelete();
|
|
return IPC_OK();
|
|
}
|
|
|
|
namespace {
|
|
|
|
void ResolveUnregister(
|
|
PServiceWorkerRegistrationParent::UnregisterResolver&& aResolver,
|
|
bool aSuccess, nsresult aRv) {
|
|
aResolver(Tuple<const bool&, const CopyableErrorResult&>(
|
|
aSuccess, CopyableErrorResult(aRv)));
|
|
}
|
|
|
|
} // anonymous namespace
|
|
|
|
IPCResult ServiceWorkerRegistrationParent::RecvUnregister(
|
|
UnregisterResolver&& aResolver) {
|
|
if (!mProxy) {
|
|
ResolveUnregister(std::move(aResolver), false,
|
|
NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
return IPC_OK();
|
|
}
|
|
|
|
mProxy->Unregister()->Then(
|
|
GetCurrentSerialEventTarget(), __func__,
|
|
[aResolver](bool aSuccess) mutable {
|
|
ResolveUnregister(std::move(aResolver), aSuccess, NS_OK);
|
|
},
|
|
[aResolver](nsresult aRv) mutable {
|
|
ResolveUnregister(std::move(aResolver), false, aRv);
|
|
});
|
|
|
|
return IPC_OK();
|
|
}
|
|
|
|
IPCResult ServiceWorkerRegistrationParent::RecvUpdate(
|
|
const nsCString& aNewestWorkerScriptUrl, UpdateResolver&& aResolver) {
|
|
if (!mProxy) {
|
|
aResolver(CopyableErrorResult(NS_ERROR_DOM_INVALID_STATE_ERR));
|
|
return IPC_OK();
|
|
}
|
|
|
|
mProxy->Update(aNewestWorkerScriptUrl)
|
|
->Then(
|
|
GetCurrentSerialEventTarget(), __func__,
|
|
[aResolver](const ServiceWorkerRegistrationDescriptor& aDescriptor) {
|
|
aResolver(aDescriptor.ToIPC());
|
|
},
|
|
[aResolver](const CopyableErrorResult& aResult) {
|
|
aResolver(aResult);
|
|
});
|
|
|
|
return IPC_OK();
|
|
}
|
|
|
|
IPCResult ServiceWorkerRegistrationParent::RecvSetNavigationPreloadEnabled(
|
|
const bool& aEnabled, SetNavigationPreloadEnabledResolver&& aResolver) {
|
|
if (!mProxy) {
|
|
aResolver(false);
|
|
return IPC_OK();
|
|
}
|
|
|
|
mProxy->SetNavigationPreloadEnabled(aEnabled)->Then(
|
|
GetCurrentSerialEventTarget(), __func__,
|
|
[aResolver](bool) { aResolver(true); },
|
|
[aResolver](nsresult) { aResolver(false); });
|
|
|
|
return IPC_OK();
|
|
}
|
|
|
|
IPCResult ServiceWorkerRegistrationParent::RecvSetNavigationPreloadHeader(
|
|
const nsCString& aHeader, SetNavigationPreloadHeaderResolver&& aResolver) {
|
|
if (!mProxy) {
|
|
aResolver(false);
|
|
return IPC_OK();
|
|
}
|
|
|
|
mProxy->SetNavigationPreloadHeader(aHeader)->Then(
|
|
GetCurrentSerialEventTarget(), __func__,
|
|
[aResolver](bool) { aResolver(true); },
|
|
[aResolver](nsresult) { aResolver(false); });
|
|
|
|
return IPC_OK();
|
|
}
|
|
|
|
IPCResult ServiceWorkerRegistrationParent::RecvGetNavigationPreloadState(
|
|
GetNavigationPreloadStateResolver&& aResolver) {
|
|
if (!mProxy) {
|
|
aResolver(Nothing());
|
|
return IPC_OK();
|
|
}
|
|
|
|
mProxy->GetNavigationPreloadState()->Then(
|
|
GetCurrentSerialEventTarget(), __func__,
|
|
[aResolver](const IPCNavigationPreloadState& aState) {
|
|
aResolver(Some(aState));
|
|
},
|
|
[aResolver](const CopyableErrorResult& aResult) {
|
|
aResolver(Nothing());
|
|
});
|
|
|
|
return IPC_OK();
|
|
}
|
|
|
|
ServiceWorkerRegistrationParent::ServiceWorkerRegistrationParent()
|
|
: mDeleteSent(false) {}
|
|
|
|
ServiceWorkerRegistrationParent::~ServiceWorkerRegistrationParent() {
|
|
MOZ_DIAGNOSTIC_ASSERT(!mProxy);
|
|
}
|
|
|
|
void ServiceWorkerRegistrationParent::Init(
|
|
const IPCServiceWorkerRegistrationDescriptor& aDescriptor) {
|
|
MOZ_DIAGNOSTIC_ASSERT(!mProxy);
|
|
mProxy = new ServiceWorkerRegistrationProxy(
|
|
ServiceWorkerRegistrationDescriptor(aDescriptor));
|
|
mProxy->Init(this);
|
|
}
|
|
|
|
void ServiceWorkerRegistrationParent::MaybeSendDelete() {
|
|
if (mDeleteSent) {
|
|
return;
|
|
}
|
|
mDeleteSent = true;
|
|
Unused << Send__delete__(this);
|
|
}
|
|
|
|
} // namespace dom
|
|
} // namespace mozilla
|