@prove-identity/prove-auth 2.10.1 → 2.14.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/bundle/release/prove-auth.js +1 -1
- package/build/lib/index.d.ts +2 -2
- package/build/lib/index.js +4 -1
- package/build/lib/proveauth/authenticator-builder.d.ts +3 -2
- package/build/lib/proveauth/authenticator-builder.js +9 -3
- package/build/lib/proveauth/instantlink.d.ts +17 -3
- package/build/lib/proveauth/instantlink.js +16 -0
- package/build/lib/proveauth/internal/auth-request.d.ts +0 -2
- package/build/lib/proveauth/internal/auth-session.d.ts +4 -0
- package/build/lib/proveauth/internal/auth-session.js +33 -7
- package/build/lib/proveauth/internal/auth-token-claims.d.ts +2 -0
- package/build/lib/proveauth/internal/device-passive-register-step.js +8 -9
- package/build/lib/proveauth/internal/device-passive-silent-step.js +8 -0
- package/build/lib/proveauth/internal/device-passive-step.js +6 -3
- package/build/lib/proveauth/internal/device-passive-stepup-step.js +1 -19
- package/build/lib/proveauth/internal/device-passive-verify-step.js +2 -18
- package/build/lib/proveauth/internal/main-authenticator.js +3 -0
- package/build/lib/proveauth/internal/mobile-instantlink-step.d.ts +7 -3
- package/build/lib/proveauth/internal/mobile-instantlink-step.js +140 -29
- package/build/lib/proveauth/internal/mobile-otp-step.d.ts +1 -0
- package/build/lib/proveauth/internal/mobile-otp-step.js +24 -1
- package/build/lib/proveauth/internal/settings.d.ts +3 -0
- package/build/lib/proveauth/internal/settings.js +14 -0
- package/build/lib/proveauth/otp.d.ts +2 -1
- package/build/lib/proveauth/otp.js +1 -0
- package/build/lib/proveauth/version.d.ts +2 -2
- package/build/lib/proveauth/version.js +2 -2
- package/package.json +1 -1
|
@@ -122,6 +122,24 @@ class MobileOtpStep {
|
|
|
122
122
|
}
|
|
123
123
|
return;
|
|
124
124
|
}
|
|
125
|
+
resendOtp(session, otpStartStep, otpFinishStep, phoneNumberNeeded) {
|
|
126
|
+
return new Promise((resolve, reject) => {
|
|
127
|
+
session
|
|
128
|
+
.fetchFromBackend('/v1/client/mobile/otp/start', {})
|
|
129
|
+
.then((response) => {
|
|
130
|
+
const authResponse = response;
|
|
131
|
+
if (authResponse.error) {
|
|
132
|
+
reject(new auth_error_1.default(authResponse.error.message, authResponse.error.code, response.next, false));
|
|
133
|
+
}
|
|
134
|
+
else {
|
|
135
|
+
this.runOtpFinishStep(session, otpStartStep, otpFinishStep, phoneNumberNeeded)
|
|
136
|
+
.then(resolve)
|
|
137
|
+
.catch(reject);
|
|
138
|
+
}
|
|
139
|
+
})
|
|
140
|
+
.catch(reject);
|
|
141
|
+
});
|
|
142
|
+
}
|
|
125
143
|
runOtpFinishStep(session, otpStartStep, otpFinishStep, phoneNumberNeeded, otpError) {
|
|
126
144
|
return new Promise((resolve, reject) => {
|
|
127
145
|
otpFinishStep
|
|
@@ -136,7 +154,7 @@ class MobileOtpStep {
|
|
|
136
154
|
else {
|
|
137
155
|
switch (result.resultType) {
|
|
138
156
|
case otp_1.OtpFinishResultType.OnResendOtp:
|
|
139
|
-
this.
|
|
157
|
+
this.resendOtp(session, otpStartStep, otpFinishStep, phoneNumberNeeded)
|
|
140
158
|
.then(resolve)
|
|
141
159
|
.catch(reject);
|
|
142
160
|
break;
|
|
@@ -175,6 +193,11 @@ class MobileOtpStep {
|
|
|
175
193
|
})
|
|
176
194
|
.catch(reject);
|
|
177
195
|
break;
|
|
196
|
+
case otp_1.OtpFinishResultType.OnMobileNumberChange:
|
|
197
|
+
this.runOtpStartStep(session, otpStartStep, otpFinishStep, true)
|
|
198
|
+
.then(resolve)
|
|
199
|
+
.catch(reject);
|
|
200
|
+
break;
|
|
178
201
|
}
|
|
179
202
|
}
|
|
180
203
|
})
|
|
@@ -3,6 +3,7 @@ export default class Settings {
|
|
|
3
3
|
static readonly DEVICE_ID_KEY = "DeviceId";
|
|
4
4
|
static readonly NAMESPACE_KEY = "namespace";
|
|
5
5
|
static readonly FIDO_PASSKEY_REGISTERED_KEY = "fidoPasskeyRegistered";
|
|
6
|
+
static readonly FP_TIMESTAMPT = "fingerPrintTimestamp";
|
|
6
7
|
private readonly log;
|
|
7
8
|
private storage;
|
|
8
9
|
upkEnabled: boolean;
|
|
@@ -11,6 +12,8 @@ export default class Settings {
|
|
|
11
12
|
get deviceId(): string | null;
|
|
12
13
|
set deviceId(val: string | null);
|
|
13
14
|
get fidoPasskeyRegistered(): boolean;
|
|
15
|
+
set fingerPrintTimestamp(val: number | null);
|
|
16
|
+
get fingerPrintTimestamp(): number | null;
|
|
14
17
|
set fidoPasskeyRegistered(val: boolean);
|
|
15
18
|
get namespace(): string | null;
|
|
16
19
|
set namespace(val: string | null);
|
|
@@ -12,6 +12,7 @@ class Settings {
|
|
|
12
12
|
this.deviceId = null;
|
|
13
13
|
this.namespace = null;
|
|
14
14
|
this.fidoPasskeyRegistered = false;
|
|
15
|
+
this.fingerPrintTimestamp = null;
|
|
15
16
|
}
|
|
16
17
|
get deviceId() {
|
|
17
18
|
return this.storage.getItem(this.getKey(Settings.DEVICE_ID_KEY));
|
|
@@ -22,6 +23,18 @@ class Settings {
|
|
|
22
23
|
get fidoPasskeyRegistered() {
|
|
23
24
|
return this.storage.getItem(this.getKey(Settings.FIDO_PASSKEY_REGISTERED_KEY)) === 'true';
|
|
24
25
|
}
|
|
26
|
+
set fingerPrintTimestamp(val) {
|
|
27
|
+
const assignedValue = val !== null ? val.toString() : null;
|
|
28
|
+
this.setOrRemove(Settings.FP_TIMESTAMPT, assignedValue);
|
|
29
|
+
}
|
|
30
|
+
get fingerPrintTimestamp() {
|
|
31
|
+
const storedTimestampString = this.storage.getItem(this.getKey(Settings.FP_TIMESTAMPT));
|
|
32
|
+
if (!storedTimestampString) {
|
|
33
|
+
return null;
|
|
34
|
+
}
|
|
35
|
+
let fingerprintTimestamp = parseInt(storedTimestampString);
|
|
36
|
+
return isNaN(fingerprintTimestamp) ? null : fingerprintTimestamp;
|
|
37
|
+
}
|
|
25
38
|
set fidoPasskeyRegistered(val) {
|
|
26
39
|
this.setOrRemove(Settings.FIDO_PASSKEY_REGISTERED_KEY, val ? 'true' : null);
|
|
27
40
|
}
|
|
@@ -48,4 +61,5 @@ Settings.KEY_PREFIX = 'ProveAuth';
|
|
|
48
61
|
Settings.DEVICE_ID_KEY = 'DeviceId';
|
|
49
62
|
Settings.NAMESPACE_KEY = 'namespace';
|
|
50
63
|
Settings.FIDO_PASSKEY_REGISTERED_KEY = 'fidoPasskeyRegistered';
|
|
64
|
+
Settings.FP_TIMESTAMPT = 'fingerPrintTimestamp';
|
|
51
65
|
exports.default = Settings;
|
|
@@ -8,7 +8,8 @@ export type OtpStartStep = PhoneNumberStep;
|
|
|
8
8
|
export type OtpStartStepFn = PhoneNumberStepFn;
|
|
9
9
|
export declare enum OtpFinishResultType {
|
|
10
10
|
OnSuccess = 0,
|
|
11
|
-
OnResendOtp = 1
|
|
11
|
+
OnResendOtp = 1,
|
|
12
|
+
OnMobileNumberChange = 2
|
|
12
13
|
}
|
|
13
14
|
export interface OtpFinishResult {
|
|
14
15
|
resultType: OtpFinishResultType;
|
|
@@ -15,4 +15,5 @@ var OtpFinishResultType;
|
|
|
15
15
|
(function (OtpFinishResultType) {
|
|
16
16
|
OtpFinishResultType[OtpFinishResultType["OnSuccess"] = 0] = "OnSuccess";
|
|
17
17
|
OtpFinishResultType[OtpFinishResultType["OnResendOtp"] = 1] = "OnResendOtp";
|
|
18
|
+
OtpFinishResultType[OtpFinishResultType["OnMobileNumberChange"] = 2] = "OnMobileNumberChange";
|
|
18
19
|
})(OtpFinishResultType = exports.OtpFinishResultType || (exports.OtpFinishResultType = {}));
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export declare const VERSION = "2.
|
|
2
|
-
export declare const API_CONTRACT_VERSION = "2.
|
|
1
|
+
export declare const VERSION = "2.14.0";
|
|
2
|
+
export declare const API_CONTRACT_VERSION = "2.14.0";
|
|
3
3
|
export declare const USER_AGENT_VERSIONS: string;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.USER_AGENT_VERSIONS = exports.API_CONTRACT_VERSION = exports.VERSION = void 0;
|
|
4
|
-
exports.VERSION = '2.
|
|
5
|
-
exports.API_CONTRACT_VERSION = '2.
|
|
4
|
+
exports.VERSION = '2.14.0';
|
|
5
|
+
exports.API_CONTRACT_VERSION = '2.14.0';
|
|
6
6
|
exports.USER_AGENT_VERSIONS = `ProveAuth/${exports.VERSION} Contract/${exports.API_CONTRACT_VERSION} WEB/1`;
|