summaryrefslogtreecommitdiffstats
path: root/dom/webauthn/WebAuthnPromiseHolder.cpp
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
commit26a029d407be480d791972afb5975cf62c9360a6 (patch)
treef435a8308119effd964b339f76abb83a57c29483 /dom/webauthn/WebAuthnPromiseHolder.cpp
parentInitial commit. (diff)
downloadfirefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz
firefox-26a029d407be480d791972afb5975cf62c9360a6.zip
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/webauthn/WebAuthnPromiseHolder.cpp')
-rw-r--r--dom/webauthn/WebAuthnPromiseHolder.cpp88
1 files changed, 88 insertions, 0 deletions
diff --git a/dom/webauthn/WebAuthnPromiseHolder.cpp b/dom/webauthn/WebAuthnPromiseHolder.cpp
new file mode 100644
index 0000000000..60dff7f1c2
--- /dev/null
+++ b/dom/webauthn/WebAuthnPromiseHolder.cpp
@@ -0,0 +1,88 @@
+/* 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/AppShutdown.h"
+#include "WebAuthnPromiseHolder.h"
+
+namespace mozilla::dom {
+
+NS_IMPL_ISUPPORTS(WebAuthnRegisterPromiseHolder, nsIWebAuthnRegisterPromise);
+
+already_AddRefed<WebAuthnRegisterPromise>
+WebAuthnRegisterPromiseHolder::Ensure() {
+ return mRegisterPromise.Ensure(__func__);
+}
+
+NS_IMETHODIMP
+WebAuthnRegisterPromiseHolder::Resolve(nsIWebAuthnRegisterResult* aResult) {
+ if (AppShutdown::IsInOrBeyond(ShutdownPhase::XPCOMShutdownThreads)) {
+ return NS_ERROR_ILLEGAL_DURING_SHUTDOWN;
+ }
+
+ // Resolve the promise on its owning thread if Disconnect() has not been
+ // called.
+ RefPtr<nsIWebAuthnRegisterResult> result(aResult);
+ mEventTarget->Dispatch(NS_NewRunnableFunction(
+ "WebAuthnRegisterPromiseHolder::Resolve",
+ [self = RefPtr{this}, result]() {
+ self->mRegisterPromise.ResolveIfExists(result, __func__);
+ }));
+ return NS_OK;
+}
+
+NS_IMETHODIMP
+WebAuthnRegisterPromiseHolder::Reject(nsresult aResult) {
+ if (AppShutdown::IsInOrBeyond(ShutdownPhase::XPCOMShutdownThreads)) {
+ return NS_ERROR_ILLEGAL_DURING_SHUTDOWN;
+ }
+
+ // Reject the promise on its owning thread if Disconnect() has not been
+ // called.
+ mEventTarget->Dispatch(NS_NewRunnableFunction(
+ "WebAuthnRegisterPromiseHolder::Reject",
+ [self = RefPtr{this}, aResult]() {
+ self->mRegisterPromise.RejectIfExists(aResult, __func__);
+ }));
+ return NS_OK;
+}
+
+NS_IMPL_ISUPPORTS(WebAuthnSignPromiseHolder, nsIWebAuthnSignPromise);
+
+already_AddRefed<WebAuthnSignPromise> WebAuthnSignPromiseHolder::Ensure() {
+ return mSignPromise.Ensure(__func__);
+}
+
+NS_IMETHODIMP
+WebAuthnSignPromiseHolder::Resolve(nsIWebAuthnSignResult* aResult) {
+ if (AppShutdown::IsInOrBeyond(ShutdownPhase::XPCOMShutdownThreads)) {
+ return NS_ERROR_ILLEGAL_DURING_SHUTDOWN;
+ }
+
+ // Resolve the promise on its owning thread if Disconnect() has not been
+ // called.
+ RefPtr<nsIWebAuthnSignResult> result(aResult);
+ mEventTarget->Dispatch(NS_NewRunnableFunction(
+ "WebAuthnSignPromiseHolder::Resolve", [self = RefPtr{this}, result]() {
+ self->mSignPromise.ResolveIfExists(result, __func__);
+ }));
+ return NS_OK;
+}
+
+NS_IMETHODIMP
+WebAuthnSignPromiseHolder::Reject(nsresult aResult) {
+ if (AppShutdown::IsInOrBeyond(ShutdownPhase::XPCOMShutdownThreads)) {
+ return NS_ERROR_ILLEGAL_DURING_SHUTDOWN;
+ }
+
+ // Reject the promise on its owning thread if Disconnect() has not been
+ // called.
+ mEventTarget->Dispatch(NS_NewRunnableFunction(
+ "WebAuthnSignPromiseHolder::Reject", [self = RefPtr{this}, aResult]() {
+ self->mSignPromise.RejectIfExists(aResult, __func__);
+ }));
+
+ return NS_OK;
+}
+
+} // namespace mozilla::dom