gecko-dev/dom/webauthn/WebAuthnTransactionParent.cpp

190 строки
5.5 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 "mozilla/dom/WebAuthnTransactionParent.h"
#include "mozilla/dom/WebAuthnController.h"
#include "mozilla/ipc/PBackgroundParent.h"
#include "mozilla/ipc/BackgroundParent.h"
#include "mozilla/StaticPrefs_security.h"
#include "nsThreadUtils.h"
#ifdef MOZ_WIDGET_ANDROID
# include "mozilla/dom/U2FTokenManager.h"
#endif
#ifdef XP_WIN
# include "WinWebAuthnManager.h"
#endif
namespace mozilla::dom {
mozilla::ipc::IPCResult WebAuthnTransactionParent::RecvRequestRegister(
const uint64_t& aTransactionId,
const WebAuthnMakeCredentialInfo& aTransactionInfo) {
::mozilla::ipc::AssertIsOnBackgroundThread();
#ifdef XP_WIN
bool usingTestToken =
StaticPrefs::security_webauth_webauthn_enable_softtoken();
if (!usingTestToken && WinWebAuthnManager::AreWebAuthNApisAvailable()) {
WinWebAuthnManager* mgr = WinWebAuthnManager::Get();
if (mgr) {
mgr->Register(this, aTransactionId, aTransactionInfo);
}
return IPC_OK();
}
#endif
// Bug 1819414 will reroute requests on Android through WebAuthnController and
// allow us to remove this.
#ifdef MOZ_WIDGET_ANDROID
bool usingTestToken =
StaticPrefs::security_webauth_webauthn_enable_softtoken();
bool androidFido2 =
StaticPrefs::security_webauth_webauthn_enable_android_fido2();
if (!usingTestToken && androidFido2) {
U2FTokenManager* mgr = U2FTokenManager::Get();
if (mgr) {
mgr->Register(this, aTransactionId, aTransactionInfo);
}
return IPC_OK();
}
#endif
WebAuthnController* ctrl = WebAuthnController::Get();
if (ctrl) {
ctrl->Register(this, aTransactionId, aTransactionInfo);
}
return IPC_OK();
}
mozilla::ipc::IPCResult WebAuthnTransactionParent::RecvRequestSign(
const uint64_t& aTransactionId,
const WebAuthnGetAssertionInfo& aTransactionInfo) {
::mozilla::ipc::AssertIsOnBackgroundThread();
#ifdef XP_WIN
bool usingTestToken =
StaticPrefs::security_webauth_webauthn_enable_softtoken();
if (!usingTestToken && WinWebAuthnManager::AreWebAuthNApisAvailable()) {
WinWebAuthnManager* mgr = WinWebAuthnManager::Get();
if (mgr) {
mgr->Sign(this, aTransactionId, aTransactionInfo);
}
return IPC_OK();
}
#endif
// Bug 1819414 will reroute requests on Android through WebAuthnController and
// allow us to remove this.
#ifdef MOZ_WIDGET_ANDROID
bool usingTestToken =
StaticPrefs::security_webauth_webauthn_enable_softtoken();
bool androidFido2 =
StaticPrefs::security_webauth_webauthn_enable_android_fido2();
if (!usingTestToken && androidFido2) {
U2FTokenManager* mgr = U2FTokenManager::Get();
if (mgr) {
mgr->Sign(this, aTransactionId, aTransactionInfo);
}
return IPC_OK();
}
#endif
WebAuthnController* ctrl = WebAuthnController::Get();
ctrl->Sign(this, aTransactionId, aTransactionInfo);
return IPC_OK();
}
mozilla::ipc::IPCResult WebAuthnTransactionParent::RecvRequestCancel(
const Tainted<uint64_t>& aTransactionId) {
::mozilla::ipc::AssertIsOnBackgroundThread();
#ifdef XP_WIN
if (WinWebAuthnManager::AreWebAuthNApisAvailable()) {
WinWebAuthnManager* mgr = WinWebAuthnManager::Get();
if (mgr) {
mgr->Cancel(this, aTransactionId);
}
}
// fall through in case WebAuthnController was used.
#endif
// Bug 1819414 will reroute requests on Android through WebAuthnController and
// allow us to remove this.
#ifdef MOZ_WIDGET_ANDROID
U2FTokenManager* mgr = U2FTokenManager::Get();
if (mgr) {
mgr->Cancel(this, aTransactionId);
}
// fall through in case WebAuthnController was used.
#endif
WebAuthnController* ctrl = WebAuthnController::Get();
if (ctrl) {
ctrl->Cancel(this, aTransactionId);
}
return IPC_OK();
}
mozilla::ipc::IPCResult WebAuthnTransactionParent::RecvDestroyMe() {
::mozilla::ipc::AssertIsOnBackgroundThread();
// The child was disconnected from the WebAuthnManager instance and will send
// no further messages. It is kept alive until we delete it explicitly.
// The child should have cancelled any active transaction. This means
// we expect no more messages to the child. We'll crash otherwise.
// The IPC roundtrip is complete. No more messages, hopefully.
IProtocol* mgr = Manager();
if (!Send__delete__(this)) {
return IPC_FAIL_NO_REASON(mgr);
}
return IPC_OK();
}
void WebAuthnTransactionParent::ActorDestroy(ActorDestroyReason aWhy) {
::mozilla::ipc::AssertIsOnBackgroundThread();
// Called either by Send__delete__() in RecvDestroyMe() above, or when
// the channel disconnects. Ensure the token manager forgets about us.
#ifdef XP_WIN
if (WinWebAuthnManager::AreWebAuthNApisAvailable()) {
WinWebAuthnManager* mgr = WinWebAuthnManager::Get();
if (mgr) {
mgr->MaybeClearTransaction(this);
}
}
// fall through in case WebAuthnController was used.
#endif
// Bug 1819414 will reroute requests on Android through WebAuthnController and
// allow us to remove this.
#ifdef MOZ_WIDGET_ANDROID
U2FTokenManager* mgr = U2FTokenManager::Get();
if (mgr) {
mgr->MaybeClearTransaction(this);
}
// fall through in case WebAuthnController was used.
#endif
WebAuthnController* ctrl = WebAuthnController::Get();
if (ctrl) {
ctrl->MaybeClearTransaction(this);
}
}
} // namespace mozilla::dom