react-native-authsignal 0.2.0 → 0.2.2
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/{LICENSE → LICENSE.md} +3 -2
- package/README.md +1 -21
- package/android/build.gradle +2 -2
- package/android/src/main/java/com/authsignal/react/AuthsignalPasskeyModule.java +14 -2
- package/android/src/main/java/com/authsignal/react/AuthsignalPushModule.java +34 -8
- package/ios/AuthsignalPasskeyModule.swift +34 -7
- package/ios/AuthsignalPushModule.swift +94 -24
- package/lib/commonjs/index.js +24 -3
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/passkey.js +44 -8
- package/lib/commonjs/passkey.js.map +1 -1
- package/lib/commonjs/push.js +84 -6
- package/lib/commonjs/push.js.map +1 -1
- package/lib/commonjs/types.js +2 -0
- package/lib/commonjs/types.js.map +1 -0
- package/lib/module/index.js +9 -3
- package/lib/module/index.js.map +1 -1
- package/lib/module/passkey.js +44 -8
- package/lib/module/passkey.js.map +1 -1
- package/lib/module/push.js +84 -6
- package/lib/module/push.js.map +1 -1
- package/lib/module/types.js +2 -0
- package/lib/module/types.js.map +1 -0
- package/lib/typescript/index.d.ts +4 -2
- package/lib/typescript/index.d.ts.map +1 -1
- package/lib/typescript/passkey.d.ts +6 -3
- package/lib/typescript/passkey.d.ts.map +1 -1
- package/lib/typescript/push.d.ts +9 -6
- package/lib/typescript/push.d.ts.map +1 -1
- package/lib/typescript/types.d.ts +20 -0
- package/lib/typescript/types.d.ts.map +1 -0
- package/package.json +6 -2
- package/react-native-authsignal.podspec +1 -1
- package/src/index.tsx +8 -2
- package/src/passkey.ts +44 -10
- package/src/push.ts +88 -15
- package/src/types.ts +20 -0
package/{LICENSE → LICENSE.md}
RENAMED
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
MIT License
|
|
1
|
+
The MIT License (MIT)
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2023 Authsignal
|
|
2
4
|
|
|
3
|
-
Copyright (c) 2022 Authsignal
|
|
4
5
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
5
6
|
of this software and associated documentation files (the "Software"), to deal
|
|
6
7
|
in the Software without restriction, including without limitation the rights
|
package/README.md
CHANGED
|
@@ -1,23 +1,3 @@
|
|
|
1
1
|
# react-native-authsignal
|
|
2
2
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
## Installation
|
|
6
|
-
|
|
7
|
-
```sh
|
|
8
|
-
npm install react-native-authsignal
|
|
9
|
-
```
|
|
10
|
-
|
|
11
|
-
## Usage
|
|
12
|
-
|
|
13
|
-
```js
|
|
14
|
-
import { launch } from 'react-native-authsignal';
|
|
15
|
-
|
|
16
|
-
const token = await launch(url);
|
|
17
|
-
|
|
18
|
-
if (token) {
|
|
19
|
-
// Send token to backend to validate challenge attempt
|
|
20
|
-
} else {
|
|
21
|
-
// Challenge not completed e.g. user cancelled
|
|
22
|
-
}
|
|
23
|
-
```
|
|
3
|
+
Check out our [official React Native documentation](https://docs.authsignal.com/sdks/client/react-native).
|
package/android/build.gradle
CHANGED
|
@@ -129,8 +129,8 @@ dependencies {
|
|
|
129
129
|
|
|
130
130
|
implementation "androidx.browser:browser:1.2.0"
|
|
131
131
|
|
|
132
|
-
implementation("com.authsignal:authsignal-push-android:0.1.
|
|
133
|
-
implementation("com.authsignal:authsignal-passkey-android:0.0.
|
|
132
|
+
implementation("com.authsignal:authsignal-push-android:0.1.12")
|
|
133
|
+
implementation("com.authsignal:authsignal-passkey-android:0.0.5")
|
|
134
134
|
}
|
|
135
135
|
|
|
136
136
|
if (isNewArchitectureEnabled()) {
|
|
@@ -61,7 +61,13 @@ public class AuthsignalPasskeyModule extends ReactContextBaseJavaModule {
|
|
|
61
61
|
if (authsignalPasskey != null) {
|
|
62
62
|
authsignalPasskey
|
|
63
63
|
.signUpAsync(token, userName)
|
|
64
|
-
.thenAcceptAsync(
|
|
64
|
+
.thenAcceptAsync(response -> {
|
|
65
|
+
if (response.getError() != null) {
|
|
66
|
+
promise.reject("signUp error", response.getError());
|
|
67
|
+
} else {
|
|
68
|
+
promise.resolve(response.getData());
|
|
69
|
+
}
|
|
70
|
+
});
|
|
65
71
|
} else {
|
|
66
72
|
Log.w(TAG, INIT_WARNING);
|
|
67
73
|
|
|
@@ -74,7 +80,13 @@ public class AuthsignalPasskeyModule extends ReactContextBaseJavaModule {
|
|
|
74
80
|
if (authsignalPasskey != null) {
|
|
75
81
|
authsignalPasskey
|
|
76
82
|
.signInAsync(token)
|
|
77
|
-
.thenAcceptAsync(
|
|
83
|
+
.thenAcceptAsync(response -> {
|
|
84
|
+
if (response.getError() != null) {
|
|
85
|
+
promise.reject("signIn error", response.getError());
|
|
86
|
+
} else {
|
|
87
|
+
promise.resolve(response.getData());
|
|
88
|
+
}
|
|
89
|
+
});
|
|
78
90
|
} else {
|
|
79
91
|
Log.w(TAG, INIT_WARNING);
|
|
80
92
|
|
|
@@ -5,6 +5,7 @@ import android.util.Log;
|
|
|
5
5
|
import androidx.annotation.NonNull;
|
|
6
6
|
|
|
7
7
|
import com.authsignal.push.AuthsignalPush;
|
|
8
|
+
import com.authsignal.push.models.PushCredential;
|
|
8
9
|
import com.facebook.react.bridge.Arguments;
|
|
9
10
|
import com.facebook.react.bridge.Promise;
|
|
10
11
|
import com.facebook.react.bridge.ReactApplicationContext;
|
|
@@ -53,15 +54,16 @@ public class AuthsignalPushModule extends ReactContextBaseJavaModule {
|
|
|
53
54
|
if (authsignalPush != null) {
|
|
54
55
|
authsignalPush
|
|
55
56
|
.getCredentialAsync()
|
|
56
|
-
.thenAcceptAsync((
|
|
57
|
-
if (
|
|
57
|
+
.thenAcceptAsync((response) -> {
|
|
58
|
+
if (response.getError() != null) {
|
|
59
|
+
promise.reject("getCredential error", response.getError());
|
|
60
|
+
} else {
|
|
61
|
+
PushCredential credential = response.getData();
|
|
58
62
|
WritableMap map = Arguments.createMap();
|
|
59
63
|
map.putString("credentialID", credential.getCredentialID());
|
|
60
64
|
map.putString("createdAt", credential.getCreatedAt());
|
|
61
65
|
map.putString("lastAuthenticatedAt", credential.getLastAuthenticatedAt());
|
|
62
66
|
promise.resolve(map);
|
|
63
|
-
} else {
|
|
64
|
-
promise.resolve(null);
|
|
65
67
|
}
|
|
66
68
|
});
|
|
67
69
|
} else {
|
|
@@ -76,7 +78,13 @@ public class AuthsignalPushModule extends ReactContextBaseJavaModule {
|
|
|
76
78
|
if (authsignalPush != null) {
|
|
77
79
|
authsignalPush
|
|
78
80
|
.addCredentialAsync(token, null)
|
|
79
|
-
.thenAcceptAsync(
|
|
81
|
+
.thenAcceptAsync(response -> {
|
|
82
|
+
if (response.getError() != null) {
|
|
83
|
+
promise.reject("addCredential error", response.getError());
|
|
84
|
+
} else {
|
|
85
|
+
promise.resolve(response.getData());
|
|
86
|
+
}
|
|
87
|
+
});
|
|
80
88
|
} else {
|
|
81
89
|
Log.w(TAG, INIT_WARNING);
|
|
82
90
|
|
|
@@ -89,7 +97,13 @@ public class AuthsignalPushModule extends ReactContextBaseJavaModule {
|
|
|
89
97
|
if (authsignalPush != null) {
|
|
90
98
|
authsignalPush
|
|
91
99
|
.removeCredentialAsync()
|
|
92
|
-
.thenAcceptAsync(
|
|
100
|
+
.thenAcceptAsync(response -> {
|
|
101
|
+
if (response.getError() != null) {
|
|
102
|
+
promise.reject("removeCredential error", response.getError());
|
|
103
|
+
} else {
|
|
104
|
+
promise.resolve(response.getData());
|
|
105
|
+
}
|
|
106
|
+
});
|
|
93
107
|
} else {
|
|
94
108
|
Log.w(TAG, INIT_WARNING);
|
|
95
109
|
|
|
@@ -102,7 +116,13 @@ public class AuthsignalPushModule extends ReactContextBaseJavaModule {
|
|
|
102
116
|
if (authsignalPush != null) {
|
|
103
117
|
authsignalPush
|
|
104
118
|
.getChallengeAsync()
|
|
105
|
-
.thenAcceptAsync(
|
|
119
|
+
.thenAcceptAsync(response -> {
|
|
120
|
+
if (response.getError() != null) {
|
|
121
|
+
promise.reject("getChallenge error", response.getError());
|
|
122
|
+
} else {
|
|
123
|
+
promise.resolve(response.getData());
|
|
124
|
+
}
|
|
125
|
+
});
|
|
106
126
|
} else {
|
|
107
127
|
Log.w(TAG, INIT_WARNING);
|
|
108
128
|
|
|
@@ -120,7 +140,13 @@ public class AuthsignalPushModule extends ReactContextBaseJavaModule {
|
|
|
120
140
|
if (authsignalPush != null) {
|
|
121
141
|
authsignalPush
|
|
122
142
|
.updateChallengeAsync(challengeId, approved, verificationCode)
|
|
123
|
-
.thenAcceptAsync(
|
|
143
|
+
.thenAcceptAsync(response -> {
|
|
144
|
+
if (response.getError() != null) {
|
|
145
|
+
promise.reject("updateChallenge error", response.getError());
|
|
146
|
+
} else {
|
|
147
|
+
promise.resolve(response.getData());
|
|
148
|
+
}
|
|
149
|
+
});
|
|
124
150
|
} else {
|
|
125
151
|
Log.w(TAG, INIT_WARNING);
|
|
126
152
|
|
|
@@ -10,31 +10,58 @@ class AuthsignalPasskeyModule: NSObject {
|
|
|
10
10
|
return true
|
|
11
11
|
}
|
|
12
12
|
|
|
13
|
-
@objc func initialize(
|
|
14
|
-
|
|
13
|
+
@objc func initialize(
|
|
14
|
+
_ tenantID: NSString,
|
|
15
|
+
withBaseURL baseURL: NSString,
|
|
16
|
+
resolver resolve: @escaping RCTPromiseResolveBlock,
|
|
17
|
+
rejecter reject: @escaping RCTPromiseRejectBlock
|
|
18
|
+
) -> Void {
|
|
15
19
|
self.authsignal = AuthsignalPasskey(tenantID: tenantID as String, baseURL: baseURL as String)
|
|
16
20
|
|
|
17
21
|
resolve(nil)
|
|
18
22
|
}
|
|
19
23
|
|
|
20
|
-
@objc func signUp(
|
|
24
|
+
@objc func signUp(
|
|
25
|
+
_ token: NSString,
|
|
26
|
+
withUserName userName: NSString,
|
|
27
|
+
resolver resolve: @escaping RCTPromiseResolveBlock,
|
|
28
|
+
rejecter reject: @escaping RCTPromiseRejectBlock
|
|
29
|
+
) -> Void {
|
|
30
|
+
if (authsignal == nil) {
|
|
31
|
+
resolve(nil)
|
|
32
|
+
return
|
|
33
|
+
}
|
|
34
|
+
|
|
21
35
|
let tokenStr = token as String
|
|
22
36
|
let userNameStr = userName as String?
|
|
23
37
|
|
|
24
38
|
Task.init {
|
|
25
|
-
let
|
|
39
|
+
let response = await authsignal!.signUp(token: tokenStr, userName: userNameStr)
|
|
26
40
|
|
|
27
|
-
|
|
41
|
+
if (response.error != nil) {
|
|
42
|
+
reject("signUp error", response.error, nil)
|
|
43
|
+
} else {
|
|
44
|
+
resolve(response.data)
|
|
45
|
+
}
|
|
28
46
|
}
|
|
29
47
|
}
|
|
30
48
|
|
|
31
49
|
@objc func signIn(_ token: NSString?, withAutofill autofill: Bool, resolver resolve: @escaping RCTPromiseResolveBlock, rejecter reject: @escaping RCTPromiseRejectBlock) -> Void {
|
|
50
|
+
if (authsignal == nil) {
|
|
51
|
+
resolve(nil)
|
|
52
|
+
return
|
|
53
|
+
}
|
|
54
|
+
|
|
32
55
|
let tokenStr = token as String?
|
|
33
56
|
|
|
34
57
|
Task.init {
|
|
35
|
-
let
|
|
58
|
+
let response = await authsignal!.signIn(token: tokenStr, autofill: autofill)
|
|
36
59
|
|
|
37
|
-
|
|
60
|
+
if (response.error != nil) {
|
|
61
|
+
reject("signIn error", response.error, nil)
|
|
62
|
+
} else {
|
|
63
|
+
resolve(response.data)
|
|
64
|
+
}
|
|
38
65
|
}
|
|
39
66
|
}
|
|
40
67
|
|
|
@@ -10,66 +10,136 @@ class AuthsignalPushModule: NSObject {
|
|
|
10
10
|
return true
|
|
11
11
|
}
|
|
12
12
|
|
|
13
|
-
@objc func initialize(
|
|
14
|
-
|
|
13
|
+
@objc func initialize(
|
|
14
|
+
_ tenantID: NSString,
|
|
15
|
+
withBaseURL baseURL: NSString,
|
|
16
|
+
resolver resolve: @escaping RCTPromiseResolveBlock,
|
|
17
|
+
rejecter reject: @escaping RCTPromiseRejectBlock
|
|
18
|
+
) -> Void {
|
|
15
19
|
self.authsignal = AuthsignalPush(tenantID: tenantID as String, baseURL: baseURL as String)
|
|
16
20
|
|
|
17
21
|
resolve(nil)
|
|
18
22
|
}
|
|
19
23
|
|
|
20
|
-
@objc func getCredential(
|
|
24
|
+
@objc func getCredential(
|
|
25
|
+
_ resolve: @escaping RCTPromiseResolveBlock,
|
|
26
|
+
rejecter reject: @escaping RCTPromiseRejectBlock
|
|
27
|
+
) -> Void {
|
|
28
|
+
guard let authsignal = authsignal else {
|
|
29
|
+
resolve(nil)
|
|
30
|
+
return
|
|
31
|
+
}
|
|
32
|
+
|
|
21
33
|
Task.init {
|
|
22
|
-
let
|
|
23
|
-
|
|
24
|
-
if let
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
"
|
|
34
|
+
let response = await authsignal.getCredential()
|
|
35
|
+
|
|
36
|
+
if let error = response.error {
|
|
37
|
+
reject("getCredential error", error, nil)
|
|
38
|
+
} else if let data = response.data {
|
|
39
|
+
let credential: [String: String?] = [
|
|
40
|
+
"credentialID": response.data!.credentialID,
|
|
41
|
+
"createdAt": response.data!.createdAt,
|
|
42
|
+
"lastAuthenticatedAt": response.data!.lastAuthenticatedAt,
|
|
29
43
|
]
|
|
30
44
|
|
|
31
|
-
resolve(
|
|
45
|
+
resolve(credential)
|
|
32
46
|
} else {
|
|
33
47
|
resolve(nil)
|
|
34
48
|
}
|
|
35
49
|
}
|
|
36
50
|
}
|
|
37
51
|
|
|
38
|
-
@objc func addCredential(
|
|
52
|
+
@objc func addCredential(
|
|
53
|
+
_ token: NSString,
|
|
54
|
+
resolver resolve: @escaping RCTPromiseResolveBlock,
|
|
55
|
+
rejecter reject: @escaping RCTPromiseRejectBlock
|
|
56
|
+
) -> Void {
|
|
57
|
+
guard let authsignal = authsignal else {
|
|
58
|
+
resolve(nil)
|
|
59
|
+
return
|
|
60
|
+
}
|
|
61
|
+
|
|
39
62
|
let tokenStr = token as String
|
|
40
|
-
|
|
63
|
+
|
|
41
64
|
Task.init {
|
|
42
|
-
let
|
|
65
|
+
let response = await authsignal.addCredential(token: tokenStr)
|
|
43
66
|
|
|
44
|
-
|
|
67
|
+
if let error = response.error {
|
|
68
|
+
reject("addCredential error", error, nil)
|
|
69
|
+
} else {
|
|
70
|
+
resolve(response.data)
|
|
71
|
+
}
|
|
45
72
|
}
|
|
46
73
|
}
|
|
47
74
|
|
|
48
|
-
@objc func removeCredential(
|
|
75
|
+
@objc func removeCredential(
|
|
76
|
+
_ resolve: @escaping RCTPromiseResolveBlock,
|
|
77
|
+
rejecter reject: @escaping RCTPromiseRejectBlock
|
|
78
|
+
) -> Void {
|
|
79
|
+
guard let authsignal = authsignal else {
|
|
80
|
+
resolve(nil)
|
|
81
|
+
return
|
|
82
|
+
}
|
|
83
|
+
|
|
49
84
|
Task.init {
|
|
50
|
-
let
|
|
85
|
+
let response = await authsignal.removeCredential()
|
|
51
86
|
|
|
52
|
-
|
|
87
|
+
if let error = response.error {
|
|
88
|
+
reject("removeCredential error", error, nil)
|
|
89
|
+
} else {
|
|
90
|
+
resolve(response.data)
|
|
91
|
+
}
|
|
53
92
|
}
|
|
54
93
|
}
|
|
55
94
|
|
|
56
|
-
@objc func getChallenge(
|
|
95
|
+
@objc func getChallenge(
|
|
96
|
+
_ resolve: @escaping RCTPromiseResolveBlock,
|
|
97
|
+
rejecter reject: @escaping RCTPromiseRejectBlock
|
|
98
|
+
) -> Void {
|
|
99
|
+
guard let authsignal = authsignal else {
|
|
100
|
+
resolve(nil)
|
|
101
|
+
return
|
|
102
|
+
}
|
|
103
|
+
|
|
57
104
|
Task.init {
|
|
58
|
-
let
|
|
105
|
+
let response = await authsignal.getChallenge()
|
|
59
106
|
|
|
60
|
-
|
|
107
|
+
if let error = response.error {
|
|
108
|
+
reject("getChallenge error", error, nil)
|
|
109
|
+
} else {
|
|
110
|
+
resolve(response.data)
|
|
111
|
+
}
|
|
61
112
|
}
|
|
62
113
|
}
|
|
63
114
|
|
|
64
|
-
@objc func updateChallenge(
|
|
115
|
+
@objc func updateChallenge(
|
|
116
|
+
_ challengeID: NSString,
|
|
117
|
+
withApproval approved: Bool,
|
|
118
|
+
withVerificationCode verificationCode: NSString,
|
|
119
|
+
resolver resolve: @escaping RCTPromiseResolveBlock,
|
|
120
|
+
rejecter reject: @escaping RCTPromiseRejectBlock
|
|
121
|
+
) -> Void {
|
|
122
|
+
guard let authsignal = authsignal else {
|
|
123
|
+
resolve(nil)
|
|
124
|
+
return
|
|
125
|
+
}
|
|
126
|
+
|
|
65
127
|
let challenge = challengeID as String
|
|
66
128
|
let approval = approved as Bool
|
|
67
129
|
let code = verificationCode as String?
|
|
68
130
|
|
|
69
131
|
Task.init {
|
|
70
|
-
await authsignal
|
|
132
|
+
let response = await authsignal.updateChallenge(
|
|
133
|
+
challengeID: challenge,
|
|
134
|
+
approved: approval,
|
|
135
|
+
verificationCode: code
|
|
136
|
+
)
|
|
71
137
|
|
|
72
|
-
|
|
138
|
+
if let error = response.error {
|
|
139
|
+
reject("updateChallenge error", error, nil)
|
|
140
|
+
} else {
|
|
141
|
+
resolve(response.data)
|
|
142
|
+
}
|
|
73
143
|
}
|
|
74
144
|
}
|
|
75
145
|
}
|
package/lib/commonjs/index.js
CHANGED
|
@@ -3,12 +3,28 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
+
var _exportNames = {
|
|
7
|
+
Authsignal: true,
|
|
8
|
+
launch: true
|
|
9
|
+
};
|
|
6
10
|
exports.Authsignal = void 0;
|
|
7
11
|
exports.launch = launch;
|
|
8
12
|
var _reactNative = require("react-native");
|
|
9
13
|
var _error = require("./error");
|
|
10
14
|
var _passkey = require("./passkey");
|
|
11
15
|
var _push = require("./push");
|
|
16
|
+
var _types = require("./types");
|
|
17
|
+
Object.keys(_types).forEach(function (key) {
|
|
18
|
+
if (key === "default" || key === "__esModule") return;
|
|
19
|
+
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
20
|
+
if (key in exports && exports[key] === _types[key]) return;
|
|
21
|
+
Object.defineProperty(exports, key, {
|
|
22
|
+
enumerable: true,
|
|
23
|
+
get: function () {
|
|
24
|
+
return _types[key];
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
});
|
|
12
28
|
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
13
29
|
const AuthsignalModule = _reactNative.NativeModules.AuthsignalModule ? _reactNative.NativeModules.AuthsignalModule : new Proxy({}, {
|
|
14
30
|
get() {
|
|
@@ -19,21 +35,26 @@ class Authsignal {
|
|
|
19
35
|
constructor(_ref) {
|
|
20
36
|
let {
|
|
21
37
|
tenantID,
|
|
22
|
-
baseURL = 'https://challenge.authsignal.com/v1'
|
|
38
|
+
baseURL = 'https://challenge.authsignal.com/v1',
|
|
39
|
+
enableLogging = __DEV__
|
|
23
40
|
} = _ref;
|
|
24
41
|
_defineProperty(this, "tenantID", void 0);
|
|
25
42
|
_defineProperty(this, "baseURL", void 0);
|
|
43
|
+
_defineProperty(this, "enableLogging", void 0);
|
|
26
44
|
_defineProperty(this, "passkey", void 0);
|
|
27
45
|
_defineProperty(this, "push", void 0);
|
|
28
46
|
this.tenantID = tenantID;
|
|
29
47
|
this.baseURL = baseURL;
|
|
48
|
+
this.enableLogging = enableLogging;
|
|
30
49
|
this.passkey = new _passkey.AuthsignalPasskey({
|
|
31
50
|
tenantID,
|
|
32
|
-
baseURL
|
|
51
|
+
baseURL,
|
|
52
|
+
enableLogging
|
|
33
53
|
});
|
|
34
54
|
this.push = new _push.AuthsignalPush({
|
|
35
55
|
tenantID,
|
|
36
|
-
baseURL
|
|
56
|
+
baseURL,
|
|
57
|
+
enableLogging
|
|
37
58
|
});
|
|
38
59
|
}
|
|
39
60
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["AuthsignalModule","NativeModules","Proxy","get","Error","LINKING_ERROR","Authsignal","constructor","tenantID","baseURL","passkey","AuthsignalPasskey","push","AuthsignalPush","launch","url","Platform","OS","Promise","resolve","reject","callback","error","token"],"sourceRoot":"../../src","sources":["index.tsx"],"mappings":"
|
|
1
|
+
{"version":3,"names":["AuthsignalModule","NativeModules","Proxy","get","Error","LINKING_ERROR","Authsignal","constructor","tenantID","baseURL","enableLogging","__DEV__","passkey","AuthsignalPasskey","push","AuthsignalPush","launch","url","Platform","OS","Promise","resolve","reject","callback","error","token"],"sourceRoot":"../../src","sources":["index.tsx"],"mappings":";;;;;;;;;;;AAAA;AACA;AACA;AACA;AAEA;AAAA;EAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;AAAwB;AAExB,MAAMA,gBAAgB,GAAGC,0BAAa,CAACD,gBAAgB,GACnDC,0BAAa,CAACD,gBAAgB,GAC9B,IAAIE,KAAK,CACP,CAAC,CAAC,EACF;EACEC,GAAG,GAAG;IACJ,MAAM,IAAIC,KAAK,CAACC,oBAAa,CAAC;EAChC;AACF,CAAC,CACF;AAQE,MAAMC,UAAU,CAAC;EAQtBC,WAAW,OAIS;IAAA,IAJR;MACVC,QAAQ;MACRC,OAAO,GAAG,qCAAqC;MAC/CC,aAAa,GAAGC;IACD,CAAC;IAAA;IAAA;IAAA;IAAA;IAAA;IAChB,IAAI,CAACH,QAAQ,GAAGA,QAAQ;IACxB,IAAI,CAACC,OAAO,GAAGA,OAAO;IACtB,IAAI,CAACC,aAAa,GAAGA,aAAa;IAElC,IAAI,CAACE,OAAO,GAAG,IAAIC,0BAAiB,CAAC;MAAEL,QAAQ;MAAEC,OAAO;MAAEC;IAAc,CAAC,CAAC;IAC1E,IAAI,CAACI,IAAI,GAAG,IAAIC,oBAAc,CAAC;MAAEP,QAAQ;MAAEC,OAAO;MAAEC;IAAc,CAAC,CAAC;EACtE;AACF;AAAC;AAEM,SAASM,MAAM,CAACC,GAAW,EAA0B;EAC1D,IAAIC,qBAAQ,CAACC,EAAE,KAAK,KAAK,EAAE;IACzB,OAAOnB,gBAAgB,CAACgB,MAAM,CAACC,GAAG,CAAC;EACrC,CAAC,MAAM;IACL,OAAO,IAAIG,OAAO,CAAC,CAACC,OAAO,EAAEC,MAAM,KAAK;MACtC,MAAMC,QAAQ,GAAG,CAACC,KAAU,EAAEC,KAAa,KAAK;QAC9C,IAAIA,KAAK,EAAE;UACTJ,OAAO,CAACI,KAAK,CAAC;QAChB,CAAC,MAAM,IAAID,KAAK,EAAE;UAChB,IAAIA,KAAK,CAACA,KAAK,KAAK,gBAAgB,EAAE;YACpCH,OAAO,CAAC,IAAI,CAAC;UACf,CAAC,MAAM;YACLC,MAAM,CAACE,KAAK,CAAC;UACf;QACF,CAAC,MAAM;UACLF,MAAM,CAAC,kBAAkB,CAAC;QAC5B;MACF,CAAC;MAEDtB,gBAAgB,CAACgB,MAAM,CAACC,GAAG,EAAEM,QAAQ,CAAC;IACxC,CAAC,CAAC;EACJ;AACF"}
|
package/lib/commonjs/passkey.js
CHANGED
|
@@ -17,12 +17,15 @@ class AuthsignalPasskey {
|
|
|
17
17
|
constructor(_ref) {
|
|
18
18
|
let {
|
|
19
19
|
tenantID,
|
|
20
|
-
baseURL
|
|
20
|
+
baseURL,
|
|
21
|
+
enableLogging
|
|
21
22
|
} = _ref;
|
|
22
23
|
_defineProperty(this, "tenantID", void 0);
|
|
23
24
|
_defineProperty(this, "baseURL", void 0);
|
|
25
|
+
_defineProperty(this, "enableLogging", void 0);
|
|
24
26
|
this.tenantID = tenantID;
|
|
25
27
|
this.baseURL = baseURL;
|
|
28
|
+
this.enableLogging = enableLogging;
|
|
26
29
|
}
|
|
27
30
|
async signUp(_ref2) {
|
|
28
31
|
let {
|
|
@@ -30,7 +33,22 @@ class AuthsignalPasskey {
|
|
|
30
33
|
userName
|
|
31
34
|
} = _ref2;
|
|
32
35
|
await this.ensureModuleIsInitialized();
|
|
33
|
-
|
|
36
|
+
try {
|
|
37
|
+
const data = await AuthsignalPasskeyModule.signUp(token, userName);
|
|
38
|
+
return {
|
|
39
|
+
data
|
|
40
|
+
};
|
|
41
|
+
} catch (ex) {
|
|
42
|
+
if (this.enableLogging) {
|
|
43
|
+
console.log(ex);
|
|
44
|
+
}
|
|
45
|
+
if (ex instanceof Error) {
|
|
46
|
+
return {
|
|
47
|
+
error: ex.message
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
throw ex;
|
|
51
|
+
}
|
|
34
52
|
}
|
|
35
53
|
async signIn(_ref3) {
|
|
36
54
|
let {
|
|
@@ -38,12 +56,30 @@ class AuthsignalPasskey {
|
|
|
38
56
|
autofill = false
|
|
39
57
|
} = _ref3;
|
|
40
58
|
await this.ensureModuleIsInitialized();
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
59
|
+
try {
|
|
60
|
+
if (_reactNative.Platform.OS === 'ios') {
|
|
61
|
+
const data = await AuthsignalPasskeyModule.signIn(token, autofill);
|
|
62
|
+
return {
|
|
63
|
+
data
|
|
64
|
+
};
|
|
65
|
+
} else if (!autofill) {
|
|
66
|
+
const data = await AuthsignalPasskeyModule.signIn(token);
|
|
67
|
+
return {
|
|
68
|
+
data
|
|
69
|
+
};
|
|
70
|
+
} else {
|
|
71
|
+
throw new Error('autofill is only supported on iOS');
|
|
72
|
+
}
|
|
73
|
+
} catch (ex) {
|
|
74
|
+
if (this.enableLogging && !autofill) {
|
|
75
|
+
console.log(ex);
|
|
76
|
+
}
|
|
77
|
+
if (ex instanceof Error) {
|
|
78
|
+
return {
|
|
79
|
+
error: ex.message
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
throw ex;
|
|
47
83
|
}
|
|
48
84
|
}
|
|
49
85
|
cancel() {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["initialized","AuthsignalPasskeyModule","NativeModules","Proxy","get","Error","LINKING_ERROR","AuthsignalPasskey","constructor","tenantID","baseURL","signUp","token","userName","ensureModuleIsInitialized","signIn","autofill","Platform","OS","
|
|
1
|
+
{"version":3,"names":["initialized","AuthsignalPasskeyModule","NativeModules","Proxy","get","Error","LINKING_ERROR","AuthsignalPasskey","constructor","tenantID","baseURL","enableLogging","signUp","token","userName","ensureModuleIsInitialized","data","ex","console","log","error","message","signIn","autofill","Platform","OS","cancel","initialize"],"sourceRoot":"../../src","sources":["passkey.ts"],"mappings":";;;;;;AAAA;AACA;AAAwC;AAmBxC,IAAIA,WAAW,GAAG,KAAK;AAEvB,MAAMC,uBAAuB,GAAGC,0BAAa,CAACD,uBAAuB,GACjEC,0BAAa,CAACD,uBAAuB,GACrC,IAAIE,KAAK,CACP,CAAC,CAAC,EACF;EACEC,GAAG,GAAG;IACJ,MAAM,IAAIC,KAAK,CAACC,oBAAa,CAAC;EAChC;AACF,CAAC,CACF;AAEE,MAAMC,iBAAiB,CAAC;EAK7BC,WAAW,OAAwD;IAAA,IAAvD;MAAEC,QAAQ;MAAEC,OAAO;MAAEC;IAA+B,CAAC;IAAA;IAAA;IAAA;IAC/D,IAAI,CAACF,QAAQ,GAAGA,QAAQ;IACxB,IAAI,CAACC,OAAO,GAAGA,OAAO;IACtB,IAAI,CAACC,aAAa,GAAGA,aAAa;EACpC;EAEA,MAAMC,MAAM,QAGgD;IAAA,IAH/C;MACXC,KAAK;MACLC;IACkB,CAAC;IACnB,MAAM,IAAI,CAACC,yBAAyB,EAAE;IAEtC,IAAI;MACF,MAAMC,IAAI,GAAG,MAAMf,uBAAuB,CAACW,MAAM,CAACC,KAAK,EAAEC,QAAQ,CAAC;MAElE,OAAO;QAAEE;MAAK,CAAC;IACjB,CAAC,CAAC,OAAOC,EAAE,EAAE;MACX,IAAI,IAAI,CAACN,aAAa,EAAE;QACtBO,OAAO,CAACC,GAAG,CAACF,EAAE,CAAC;MACjB;MAEA,IAAIA,EAAE,YAAYZ,KAAK,EAAE;QACvB,OAAO;UAAEe,KAAK,EAAEH,EAAE,CAACI;QAAQ,CAAC;MAC9B;MAEA,MAAMJ,EAAE;IACV;EACF;EAEA,MAAMK,MAAM,QAGgD;IAAA,IAH/C;MACXT,KAAK;MACLU,QAAQ,GAAG;IACO,CAAC;IACnB,MAAM,IAAI,CAACR,yBAAyB,EAAE;IAEtC,IAAI;MACF,IAAIS,qBAAQ,CAACC,EAAE,KAAK,KAAK,EAAE;QACzB,MAAMT,IAAI,GAAG,MAAMf,uBAAuB,CAACqB,MAAM,CAACT,KAAK,EAAEU,QAAQ,CAAC;QAElE,OAAO;UAAEP;QAAK,CAAC;MACjB,CAAC,MAAM,IAAI,CAACO,QAAQ,EAAE;QACpB,MAAMP,IAAI,GAAG,MAAMf,uBAAuB,CAACqB,MAAM,CAACT,KAAK,CAAC;QAExD,OAAO;UAAEG;QAAK,CAAC;MACjB,CAAC,MAAM;QACL,MAAM,IAAIX,KAAK,CAAC,mCAAmC,CAAC;MACtD;IACF,CAAC,CAAC,OAAOY,EAAE,EAAE;MACX,IAAI,IAAI,CAACN,aAAa,IAAI,CAACY,QAAQ,EAAE;QACnCL,OAAO,CAACC,GAAG,CAACF,EAAE,CAAC;MACjB;MAEA,IAAIA,EAAE,YAAYZ,KAAK,EAAE;QACvB,OAAO;UAAEe,KAAK,EAAEH,EAAE,CAACI;QAAQ,CAAC;MAC9B;MAEA,MAAMJ,EAAE;IACV;EACF;EAEAS,MAAM,GAAG;IACP,IAAIF,qBAAQ,CAACC,EAAE,KAAK,KAAK,EAAE;MACzBxB,uBAAuB,CAACyB,MAAM,EAAE;IAClC;EACF;EAEA,MAAcX,yBAAyB,GAAG;IACxC,IAAIf,WAAW,EAAE;MACf;IACF;IAEA,MAAMC,uBAAuB,CAAC0B,UAAU,CAAC,IAAI,CAAClB,QAAQ,EAAE,IAAI,CAACC,OAAO,CAAC;IAErEV,WAAW,GAAG,IAAI;EACpB;AACF;AAAC"}
|
package/lib/commonjs/push.js
CHANGED
|
@@ -17,32 +17,110 @@ class AuthsignalPush {
|
|
|
17
17
|
constructor(_ref) {
|
|
18
18
|
let {
|
|
19
19
|
tenantID,
|
|
20
|
-
baseURL
|
|
20
|
+
baseURL,
|
|
21
|
+
enableLogging
|
|
21
22
|
} = _ref;
|
|
22
23
|
_defineProperty(this, "tenantID", void 0);
|
|
23
24
|
_defineProperty(this, "baseURL", void 0);
|
|
25
|
+
_defineProperty(this, "enableLogging", void 0);
|
|
24
26
|
this.tenantID = tenantID;
|
|
25
27
|
this.baseURL = baseURL;
|
|
28
|
+
this.enableLogging = enableLogging;
|
|
26
29
|
}
|
|
27
30
|
async getCredential() {
|
|
28
31
|
await this.ensureModuleIsInitialized();
|
|
29
|
-
|
|
32
|
+
try {
|
|
33
|
+
const data = await AuthsignalPushModule.getCredential();
|
|
34
|
+
return {
|
|
35
|
+
data
|
|
36
|
+
};
|
|
37
|
+
} catch (ex) {
|
|
38
|
+
if (this.enableLogging) {
|
|
39
|
+
console.log(ex);
|
|
40
|
+
}
|
|
41
|
+
if (ex instanceof Error) {
|
|
42
|
+
return {
|
|
43
|
+
error: ex.message
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
throw ex;
|
|
47
|
+
}
|
|
30
48
|
}
|
|
31
49
|
async addCredential(token) {
|
|
32
50
|
await this.ensureModuleIsInitialized();
|
|
33
|
-
|
|
51
|
+
try {
|
|
52
|
+
const data = await AuthsignalPushModule.addCredential(token);
|
|
53
|
+
return {
|
|
54
|
+
data
|
|
55
|
+
};
|
|
56
|
+
} catch (ex) {
|
|
57
|
+
if (this.enableLogging) {
|
|
58
|
+
console.log(ex);
|
|
59
|
+
}
|
|
60
|
+
if (ex instanceof Error) {
|
|
61
|
+
return {
|
|
62
|
+
error: ex.message
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
throw ex;
|
|
66
|
+
}
|
|
34
67
|
}
|
|
35
68
|
async removeCredential() {
|
|
36
69
|
await this.ensureModuleIsInitialized();
|
|
37
|
-
|
|
70
|
+
try {
|
|
71
|
+
const data = await AuthsignalPushModule.removeCredential();
|
|
72
|
+
return {
|
|
73
|
+
data
|
|
74
|
+
};
|
|
75
|
+
} catch (ex) {
|
|
76
|
+
if (this.enableLogging) {
|
|
77
|
+
console.log(ex);
|
|
78
|
+
}
|
|
79
|
+
if (ex instanceof Error) {
|
|
80
|
+
return {
|
|
81
|
+
error: ex.message
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
throw ex;
|
|
85
|
+
}
|
|
38
86
|
}
|
|
39
87
|
async getChallenge() {
|
|
40
88
|
await this.ensureModuleIsInitialized();
|
|
41
|
-
|
|
89
|
+
try {
|
|
90
|
+
const data = await AuthsignalPushModule.getChallenge();
|
|
91
|
+
return {
|
|
92
|
+
data
|
|
93
|
+
};
|
|
94
|
+
} catch (ex) {
|
|
95
|
+
if (this.enableLogging) {
|
|
96
|
+
console.log(ex);
|
|
97
|
+
}
|
|
98
|
+
if (ex instanceof Error) {
|
|
99
|
+
return {
|
|
100
|
+
error: ex.message
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
throw ex;
|
|
104
|
+
}
|
|
42
105
|
}
|
|
43
106
|
async updateChallenge(challengeId, approved, verificationCode) {
|
|
44
107
|
await this.ensureModuleIsInitialized();
|
|
45
|
-
|
|
108
|
+
try {
|
|
109
|
+
const data = await _reactNative.NativeModules.updateChallenge(challengeId, approved, verificationCode);
|
|
110
|
+
return {
|
|
111
|
+
data
|
|
112
|
+
};
|
|
113
|
+
} catch (ex) {
|
|
114
|
+
if (this.enableLogging) {
|
|
115
|
+
console.log(ex);
|
|
116
|
+
}
|
|
117
|
+
if (ex instanceof Error) {
|
|
118
|
+
return {
|
|
119
|
+
error: ex.message
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
throw ex;
|
|
123
|
+
}
|
|
46
124
|
}
|
|
47
125
|
async ensureModuleIsInitialized() {
|
|
48
126
|
if (initialized) {
|