summaryrefslogtreecommitdiffstats
path: root/dom/webauthn/WebAuthnPromiseHolder.cpp
blob: 60dff7f1c28269ed6b0e367a69ecec0bd5713a0e (plain)
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
79
80
81
82
83
84
85
86
87
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