@web3auth/no-modal 10.0.0-beta.4 → 10.0.0-beta.6
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/dist/lib.cjs/connectors/coinbase-connector/coinbaseConnector.js +4 -2
- package/dist/lib.cjs/connectors/coinbase-connector/index.js +7 -0
- package/dist/lib.cjs/index.js +0 -2
- package/dist/lib.cjs/react/solana/hooks/useSignAndSendTransaction.js +35 -0
- package/dist/lib.cjs/react/solana/hooks/useSignMessage.js +36 -0
- package/dist/lib.cjs/react/solana/hooks/useSignTransaction.js +34 -0
- package/dist/lib.cjs/react/solana/hooks/useSolanaWallet.js +52 -0
- package/dist/lib.cjs/react/solana/index.js +13 -0
- package/dist/lib.cjs/types/connectors/coinbase-connector/coinbaseConnector.d.ts +1 -1
- package/dist/lib.cjs/types/connectors/index.d.ts +0 -1
- package/dist/lib.cjs/types/react/solana/hooks/index.d.ts +4 -0
- package/dist/lib.cjs/types/react/solana/hooks/useSignAndSendTransaction.d.ts +9 -0
- package/dist/lib.cjs/types/react/solana/hooks/useSignMessage.d.ts +8 -0
- package/dist/lib.cjs/types/react/solana/hooks/useSignTransaction.d.ts +14 -0
- package/dist/lib.cjs/types/react/solana/hooks/useSolanaWallet.d.ts +6 -0
- package/dist/lib.cjs/types/react/solana/index.d.ts +1 -0
- package/dist/lib.cjs/types/vue/WalletServicesInnerProvider.d.ts +1 -0
- package/dist/lib.cjs/types/vue/composables/index.d.ts +13 -0
- package/dist/lib.cjs/types/vue/composables/useCheckout.d.ts +9 -0
- package/dist/lib.cjs/types/vue/composables/useEnableMFA.d.ts +8 -0
- package/dist/lib.cjs/types/vue/composables/useIdentityToken.d.ts +9 -0
- package/dist/lib.cjs/types/vue/composables/useManageMFA.d.ts +8 -0
- package/dist/lib.cjs/types/vue/composables/useSwap.d.ts +9 -0
- package/dist/lib.cjs/types/vue/composables/useSwitchChain.d.ts +10 -0
- package/dist/lib.cjs/types/vue/composables/useWalletConnectScanner.d.ts +9 -0
- package/dist/lib.cjs/types/vue/composables/useWalletServicesPlugin.d.ts +2 -0
- package/dist/lib.cjs/types/vue/composables/useWalletUI.d.ts +9 -0
- package/dist/lib.cjs/types/vue/composables/useWeb3Auth.d.ts +3 -0
- package/dist/lib.cjs/types/vue/composables/useWeb3AuthConnect.d.ts +10 -0
- package/dist/lib.cjs/types/vue/composables/useWeb3AuthDisconnect.d.ts +10 -0
- package/dist/lib.cjs/types/vue/composables/useWeb3AuthInner.d.ts +2 -0
- package/dist/lib.cjs/types/vue/composables/useWeb3AuthUser.d.ts +10 -0
- package/dist/lib.cjs/types/vue/{wallet-services-plugin/context.d.ts → context/WalletServicesContext.d.ts} +2 -2
- package/dist/lib.cjs/types/vue/context/index.d.ts +1 -0
- package/dist/lib.cjs/types/vue/index.d.ts +4 -2
- package/dist/lib.cjs/types/vue/interfaces.d.ts +30 -0
- package/dist/lib.cjs/vue/{wallet-services-plugin/WalletServicesProvider.js → WalletServicesInnerProvider.js} +26 -43
- package/dist/lib.cjs/vue/{no-modal/Web3AuthProvider.js → Web3AuthProvider.js} +32 -87
- package/dist/lib.cjs/vue/composables/useCheckout.js +45 -0
- package/dist/lib.cjs/vue/composables/useEnableMFA.js +43 -0
- package/dist/lib.cjs/vue/composables/useIdentityToken.js +55 -0
- package/dist/lib.cjs/vue/composables/useManageMFA.js +43 -0
- package/dist/lib.cjs/vue/composables/useSwap.js +45 -0
- package/dist/lib.cjs/vue/composables/useSwitchChain.js +43 -0
- package/dist/lib.cjs/vue/composables/useWalletConnectScanner.js +45 -0
- package/dist/lib.cjs/vue/composables/useWalletServicesPlugin.js +12 -0
- package/dist/lib.cjs/vue/composables/useWalletUI.js +45 -0
- package/dist/lib.cjs/vue/composables/useWeb3Auth.js +28 -0
- package/dist/lib.cjs/vue/composables/useWeb3AuthConnect.js +57 -0
- package/dist/lib.cjs/vue/composables/useWeb3AuthDisconnect.js +43 -0
- package/dist/lib.cjs/vue/{no-modal/composables/useWeb3Auth.js → composables/useWeb3AuthInner.js} +9 -9
- package/dist/lib.cjs/vue/composables/useWeb3AuthUser.js +64 -0
- package/dist/lib.cjs/vue/index.js +28 -8
- package/dist/lib.esm/connectors/coinbase-connector/coinbaseConnector.js +3 -1
- package/dist/lib.esm/connectors/coinbase-connector/index.js +1 -0
- package/dist/lib.esm/index.js +0 -1
- package/dist/lib.esm/react/solana/hooks/useSignAndSendTransaction.js +33 -0
- package/dist/lib.esm/react/solana/hooks/useSignMessage.js +34 -0
- package/dist/lib.esm/react/solana/hooks/useSignTransaction.js +32 -0
- package/dist/lib.esm/react/solana/hooks/useSolanaWallet.js +50 -0
- package/dist/lib.esm/react/solana/index.js +4 -0
- package/dist/lib.esm/vue/WalletServicesInnerProvider.js +79 -0
- package/dist/lib.esm/vue/{no-modal/Web3AuthProvider.js → Web3AuthProvider.js} +32 -87
- package/dist/lib.esm/vue/composables/useCheckout.js +43 -0
- package/dist/lib.esm/vue/composables/useEnableMFA.js +41 -0
- package/dist/lib.esm/vue/composables/useIdentityToken.js +53 -0
- package/dist/lib.esm/vue/composables/useManageMFA.js +41 -0
- package/dist/lib.esm/vue/composables/useSwap.js +43 -0
- package/dist/lib.esm/vue/composables/useSwitchChain.js +41 -0
- package/dist/lib.esm/vue/composables/useWalletConnectScanner.js +43 -0
- package/dist/lib.esm/vue/composables/useWalletServicesPlugin.js +10 -0
- package/dist/lib.esm/vue/composables/useWalletUI.js +43 -0
- package/dist/lib.esm/vue/composables/useWeb3Auth.js +26 -0
- package/dist/lib.esm/vue/composables/useWeb3AuthConnect.js +55 -0
- package/dist/lib.esm/vue/composables/useWeb3AuthDisconnect.js +41 -0
- package/dist/lib.esm/vue/{no-modal/composables/useWeb3Auth.js → composables/useWeb3AuthInner.js} +9 -9
- package/dist/lib.esm/vue/composables/useWeb3AuthUser.js +62 -0
- package/dist/lib.esm/vue/index.js +15 -5
- package/dist/noModal.umd.min.js +1 -1
- package/dist/noModal.umd.min.js.LICENSE.txt +4 -0
- package/package.json +27 -11
- package/dist/lib.cjs/types/vue/no-modal/composables/index.d.ts +0 -1
- package/dist/lib.cjs/types/vue/no-modal/composables/useWeb3Auth.d.ts +0 -2
- package/dist/lib.cjs/types/vue/no-modal/index.d.ts +0 -3
- package/dist/lib.cjs/types/vue/no-modal/interfaces.d.ts +0 -39
- package/dist/lib.cjs/types/vue/wallet-services-plugin/WalletServicesProvider.d.ts +0 -1
- package/dist/lib.cjs/types/vue/wallet-services-plugin/composables/index.d.ts +0 -1
- package/dist/lib.cjs/types/vue/wallet-services-plugin/composables/useWalletServicesPlugin.d.ts +0 -2
- package/dist/lib.cjs/types/vue/wallet-services-plugin/index.d.ts +0 -4
- package/dist/lib.cjs/types/vue/wallet-services-plugin/interfaces.d.ts +0 -13
- package/dist/lib.cjs/vue/wallet-services-plugin/composables/useWalletServicesPlugin.js +0 -24
- package/dist/lib.esm/vue/wallet-services-plugin/WalletServicesProvider.js +0 -96
- package/dist/lib.esm/vue/wallet-services-plugin/composables/useWalletServicesPlugin.js +0 -22
- /package/dist/lib.cjs/types/vue/{no-modal/Web3AuthProvider.d.ts → Web3AuthProvider.d.ts} +0 -0
- /package/dist/lib.cjs/vue/{wallet-services-plugin/context.js → context/WalletServicesContext.js} +0 -0
- /package/dist/lib.esm/vue/{wallet-services-plugin/context.js → context/WalletServicesContext.js} +0 -0
|
@@ -2,19 +2,20 @@
|
|
|
2
2
|
|
|
3
3
|
var vue = require('vue');
|
|
4
4
|
require('@toruslabs/base-controllers');
|
|
5
|
-
var index = require('
|
|
5
|
+
var index = require('../base/composables/index.js');
|
|
6
6
|
require('@babel/runtime/helpers/defineProperty');
|
|
7
7
|
require('@web3auth/auth');
|
|
8
|
-
var index$1 = require('
|
|
9
|
-
require('
|
|
10
|
-
var constants = require('
|
|
8
|
+
var index$1 = require('../base/errors/index.js');
|
|
9
|
+
require('../base/wallet/index.js');
|
|
10
|
+
var constants = require('../base/connector/constants.js');
|
|
11
11
|
require('jwt-decode');
|
|
12
|
-
require('
|
|
13
|
-
require('
|
|
14
|
-
require('
|
|
12
|
+
require('../base/loglevel.js');
|
|
13
|
+
require('../base/plugin/errors.js');
|
|
14
|
+
require('../base/plugin/IPlugin.js');
|
|
15
15
|
require('@toruslabs/constants');
|
|
16
16
|
require('@toruslabs/http-helpers');
|
|
17
|
-
var noModal = require('
|
|
17
|
+
var noModal = require('../noModal.js');
|
|
18
|
+
var WalletServicesInnerProvider = require('./WalletServicesInnerProvider.js');
|
|
18
19
|
|
|
19
20
|
const Web3AuthProvider = vue.defineComponent({
|
|
20
21
|
name: "Web3AuthProvider",
|
|
@@ -27,64 +28,22 @@ const Web3AuthProvider = vue.defineComponent({
|
|
|
27
28
|
setup(props) {
|
|
28
29
|
const web3Auth = vue.shallowRef(null);
|
|
29
30
|
const provider = vue.ref(null);
|
|
30
|
-
const userInfo = vue.ref(null);
|
|
31
31
|
const isMFAEnabled = vue.ref(false);
|
|
32
32
|
const status = vue.ref(null);
|
|
33
33
|
const isInitializing = vue.ref(false);
|
|
34
34
|
const initError = vue.ref(null);
|
|
35
35
|
const isInitialized = vue.ref(false);
|
|
36
|
-
const isConnecting = vue.ref(false);
|
|
37
|
-
const connectError = vue.ref(null);
|
|
38
36
|
const isConnected = vue.ref(false);
|
|
39
37
|
const getPlugin = name => {
|
|
40
38
|
if (!web3Auth.value) throw index$1.WalletInitializationError.notReady();
|
|
41
39
|
return web3Auth.value.getPlugin(name);
|
|
42
40
|
};
|
|
43
|
-
const
|
|
44
|
-
|
|
45
|
-
if (!isConnected.value) throw index$1.WalletLoginError.notConnectedError();
|
|
46
|
-
await web3Auth.value.enableMFA(loginParams);
|
|
47
|
-
const localUserInfo = await web3Auth.value.getUserInfo();
|
|
48
|
-
userInfo.value = localUserInfo;
|
|
49
|
-
isMFAEnabled.value = localUserInfo.isMfaEnabled || false;
|
|
50
|
-
};
|
|
51
|
-
const manageMFA = async loginParams => {
|
|
52
|
-
if (!web3Auth.value) throw index$1.WalletInitializationError.notReady();
|
|
53
|
-
if (!isConnected.value) throw index$1.WalletLoginError.notConnectedError();
|
|
54
|
-
await web3Auth.value.manageMFA(loginParams);
|
|
55
|
-
};
|
|
56
|
-
const logout = async (logoutParams = {
|
|
57
|
-
cleanup: false
|
|
58
|
-
}) => {
|
|
59
|
-
if (!web3Auth.value) throw index$1.WalletInitializationError.notReady();
|
|
60
|
-
if (!isConnected.value) throw index$1.WalletLoginError.notConnectedError();
|
|
61
|
-
await web3Auth.value.logout(logoutParams);
|
|
62
|
-
};
|
|
63
|
-
const connectTo = async (walletName, loginParams) => {
|
|
64
|
-
if (!web3Auth.value) throw index$1.WalletInitializationError.notReady();
|
|
65
|
-
try {
|
|
66
|
-
connectError.value = null;
|
|
67
|
-
isConnecting.value = true;
|
|
68
|
-
const localProvider = await web3Auth.value.connectTo(walletName, loginParams);
|
|
69
|
-
return localProvider;
|
|
70
|
-
} catch (error) {
|
|
71
|
-
connectError.value = error;
|
|
72
|
-
} finally {
|
|
73
|
-
isConnecting.value = false;
|
|
74
|
-
}
|
|
75
|
-
};
|
|
76
|
-
const authenticateUser = async () => {
|
|
77
|
-
if (!web3Auth.value) throw index$1.WalletInitializationError.notReady();
|
|
78
|
-
return web3Auth.value.authenticateUser();
|
|
79
|
-
};
|
|
80
|
-
const switchChain = chainParams => {
|
|
81
|
-
if (!web3Auth.value) throw index$1.WalletInitializationError.notReady();
|
|
82
|
-
return web3Auth.value.switchChain(chainParams);
|
|
41
|
+
const setIsMFAEnabled = isMfaEnabled => {
|
|
42
|
+
isMFAEnabled.value = isMfaEnabled;
|
|
83
43
|
};
|
|
84
44
|
vue.watch(() => props.config, (newConfig, _, onInvalidate) => {
|
|
85
45
|
const resetHookState = () => {
|
|
86
46
|
provider.value = null;
|
|
87
|
-
userInfo.value = null;
|
|
88
47
|
isMFAEnabled.value = false;
|
|
89
48
|
isConnected.value = false;
|
|
90
49
|
status.value = null;
|
|
@@ -104,12 +63,12 @@ const Web3AuthProvider = vue.defineComponent({
|
|
|
104
63
|
immediate: true
|
|
105
64
|
});
|
|
106
65
|
vue.watch(web3Auth, async (newWeb3Auth, _, onInvalidate) => {
|
|
66
|
+
const controller = new AbortController();
|
|
67
|
+
// Invalidate the controller here before calling any async methods.
|
|
68
|
+
onInvalidate(() => {
|
|
69
|
+
controller.abort();
|
|
70
|
+
});
|
|
107
71
|
if (newWeb3Auth) {
|
|
108
|
-
const controller = new AbortController();
|
|
109
|
-
// Invalidate the controller here before calling any async methods.
|
|
110
|
-
onInvalidate(() => {
|
|
111
|
-
controller.abort();
|
|
112
|
-
});
|
|
113
72
|
try {
|
|
114
73
|
initError.value = null;
|
|
115
74
|
isInitializing.value = true;
|
|
@@ -125,24 +84,10 @@ const Web3AuthProvider = vue.defineComponent({
|
|
|
125
84
|
}, {
|
|
126
85
|
immediate: true
|
|
127
86
|
});
|
|
128
|
-
vue.watch(isConnected, () => {
|
|
129
|
-
if (web3Auth.value) {
|
|
130
|
-
const addState = async web3AuthInstance => {
|
|
131
|
-
provider.value = web3AuthInstance.provider;
|
|
132
|
-
const userState = await web3AuthInstance.getUserInfo();
|
|
133
|
-
userInfo.value = userState;
|
|
134
|
-
isMFAEnabled.value = (userState === null || userState === void 0 ? void 0 : userState.isMfaEnabled) || false;
|
|
135
|
-
};
|
|
136
|
-
const resetState = () => {
|
|
137
|
-
provider.value = null;
|
|
138
|
-
userInfo.value = null;
|
|
139
|
-
isMFAEnabled.value = false;
|
|
140
|
-
};
|
|
141
|
-
if (isConnected.value) addState(web3Auth.value);else resetState();
|
|
142
|
-
}
|
|
143
|
-
});
|
|
144
87
|
vue.watch(web3Auth, (newWeb3Auth, prevWeb3Auth) => {
|
|
145
|
-
const notReadyListener = () =>
|
|
88
|
+
const notReadyListener = () => {
|
|
89
|
+
status.value = web3Auth.value.status;
|
|
90
|
+
};
|
|
146
91
|
const readyListener = () => {
|
|
147
92
|
status.value = web3Auth.value.status;
|
|
148
93
|
isInitialized.value = true;
|
|
@@ -151,13 +96,16 @@ const Web3AuthProvider = vue.defineComponent({
|
|
|
151
96
|
status.value = web3Auth.value.status;
|
|
152
97
|
// we do this because of rehydration issues. status connected is fired first but web3auth sdk is not ready yet.
|
|
153
98
|
if (web3Auth.value.status === constants.CONNECTOR_STATUS.CONNECTED) {
|
|
154
|
-
isInitialized.value = true;
|
|
99
|
+
if (!isInitialized.value) isInitialized.value = true;
|
|
155
100
|
isConnected.value = true;
|
|
101
|
+
provider.value = newWeb3Auth.provider;
|
|
156
102
|
}
|
|
157
103
|
};
|
|
158
104
|
const disconnectedListener = () => {
|
|
159
105
|
status.value = web3Auth.value.status;
|
|
160
106
|
isConnected.value = false;
|
|
107
|
+
provider.value = null;
|
|
108
|
+
isMFAEnabled.value = false;
|
|
161
109
|
};
|
|
162
110
|
const connectingListener = () => {
|
|
163
111
|
status.value = web3Auth.value.status;
|
|
@@ -165,6 +113,9 @@ const Web3AuthProvider = vue.defineComponent({
|
|
|
165
113
|
const errorListener = () => {
|
|
166
114
|
status.value = constants.CONNECTOR_EVENTS.ERRORED;
|
|
167
115
|
};
|
|
116
|
+
const mfaEnabledListener = () => {
|
|
117
|
+
isMFAEnabled.value = true;
|
|
118
|
+
};
|
|
168
119
|
// unregister previous listeners
|
|
169
120
|
if (prevWeb3Auth && newWeb3Auth !== prevWeb3Auth) {
|
|
170
121
|
prevWeb3Auth.off(constants.CONNECTOR_EVENTS.NOT_READY, notReadyListener);
|
|
@@ -173,6 +124,7 @@ const Web3AuthProvider = vue.defineComponent({
|
|
|
173
124
|
prevWeb3Auth.off(constants.CONNECTOR_EVENTS.DISCONNECTED, disconnectedListener);
|
|
174
125
|
prevWeb3Auth.off(constants.CONNECTOR_EVENTS.CONNECTING, connectingListener);
|
|
175
126
|
prevWeb3Auth.off(constants.CONNECTOR_EVENTS.ERRORED, errorListener);
|
|
127
|
+
prevWeb3Auth.off(constants.CONNECTOR_EVENTS.MFA_ENABLED, mfaEnabledListener);
|
|
176
128
|
}
|
|
177
129
|
if (newWeb3Auth && newWeb3Auth !== prevWeb3Auth) {
|
|
178
130
|
status.value = newWeb3Auth.status;
|
|
@@ -183,6 +135,7 @@ const Web3AuthProvider = vue.defineComponent({
|
|
|
183
135
|
newWeb3Auth.on(constants.CONNECTOR_EVENTS.DISCONNECTED, disconnectedListener);
|
|
184
136
|
newWeb3Auth.on(constants.CONNECTOR_EVENTS.CONNECTING, connectingListener);
|
|
185
137
|
newWeb3Auth.on(constants.CONNECTOR_EVENTS.ERRORED, errorListener);
|
|
138
|
+
newWeb3Auth.on(constants.CONNECTOR_EVENTS.MFA_ENABLED, mfaEnabledListener);
|
|
186
139
|
}
|
|
187
140
|
}, {
|
|
188
141
|
immediate: true
|
|
@@ -192,25 +145,17 @@ const Web3AuthProvider = vue.defineComponent({
|
|
|
192
145
|
isConnected,
|
|
193
146
|
isInitialized,
|
|
194
147
|
provider,
|
|
195
|
-
userInfo,
|
|
196
|
-
isMFAEnabled,
|
|
197
148
|
status,
|
|
198
|
-
getPlugin,
|
|
199
|
-
connectTo,
|
|
200
|
-
enableMFA,
|
|
201
|
-
manageMFA,
|
|
202
|
-
logout,
|
|
203
|
-
authenticateUser,
|
|
204
|
-
switchChain,
|
|
205
149
|
isInitializing,
|
|
206
|
-
isConnecting,
|
|
207
150
|
initError,
|
|
208
|
-
|
|
151
|
+
isMFAEnabled,
|
|
152
|
+
getPlugin,
|
|
153
|
+
setIsMFAEnabled
|
|
209
154
|
});
|
|
210
155
|
},
|
|
211
156
|
render() {
|
|
212
157
|
var _this$$slots$default;
|
|
213
|
-
return vue.h((_this$$slots$default = this.$slots.default) !== null && _this$$slots$default !== void 0 ? _this$$slots$default : "");
|
|
158
|
+
return vue.h(WalletServicesInnerProvider.WalletServicesInnerProvider, {}, (_this$$slots$default = this.$slots.default) !== null && _this$$slots$default !== void 0 ? _this$$slots$default : "");
|
|
214
159
|
}
|
|
215
160
|
});
|
|
216
161
|
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var vue = require('vue');
|
|
4
|
+
require('@toruslabs/base-controllers');
|
|
5
|
+
require('@babel/runtime/helpers/defineProperty');
|
|
6
|
+
require('@web3auth/auth');
|
|
7
|
+
require('../../base/errors/index.js');
|
|
8
|
+
require('../../base/wallet/index.js');
|
|
9
|
+
require('../../base/connector/constants.js');
|
|
10
|
+
require('jwt-decode');
|
|
11
|
+
require('../../base/loglevel.js');
|
|
12
|
+
var errors = require('../../base/plugin/errors.js');
|
|
13
|
+
require('../../base/plugin/IPlugin.js');
|
|
14
|
+
require('@toruslabs/constants');
|
|
15
|
+
require('@toruslabs/http-helpers');
|
|
16
|
+
var useWalletServicesPlugin = require('./useWalletServicesPlugin.js');
|
|
17
|
+
|
|
18
|
+
const useCheckout = () => {
|
|
19
|
+
const {
|
|
20
|
+
plugin,
|
|
21
|
+
ready
|
|
22
|
+
} = useWalletServicesPlugin.useWalletServicesPlugin();
|
|
23
|
+
const loading = vue.ref(false);
|
|
24
|
+
const error = vue.ref(null);
|
|
25
|
+
const showCheckout = async showCheckoutParams => {
|
|
26
|
+
loading.value = true;
|
|
27
|
+
error.value = null;
|
|
28
|
+
try {
|
|
29
|
+
if (!plugin) throw errors.WalletServicesPluginError.notInitialized();
|
|
30
|
+
if (!ready) throw errors.WalletServicesPluginError.walletPluginNotConnected();
|
|
31
|
+
await plugin.value.showCheckout(showCheckoutParams);
|
|
32
|
+
} catch (err) {
|
|
33
|
+
error.value = err;
|
|
34
|
+
} finally {
|
|
35
|
+
loading.value = false;
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
return {
|
|
39
|
+
loading,
|
|
40
|
+
error,
|
|
41
|
+
showCheckout
|
|
42
|
+
};
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
exports.useCheckout = useCheckout;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var vue = require('vue');
|
|
4
|
+
require('@toruslabs/base-controllers');
|
|
5
|
+
require('@babel/runtime/helpers/defineProperty');
|
|
6
|
+
require('@web3auth/auth');
|
|
7
|
+
var index = require('../../base/errors/index.js');
|
|
8
|
+
require('../../base/wallet/index.js');
|
|
9
|
+
require('../../base/connector/constants.js');
|
|
10
|
+
require('jwt-decode');
|
|
11
|
+
require('../../base/loglevel.js');
|
|
12
|
+
require('../../base/plugin/errors.js');
|
|
13
|
+
require('../../base/plugin/IPlugin.js');
|
|
14
|
+
require('@toruslabs/constants');
|
|
15
|
+
require('@toruslabs/http-helpers');
|
|
16
|
+
var useWeb3AuthInner = require('./useWeb3AuthInner.js');
|
|
17
|
+
|
|
18
|
+
const useEnableMFA = () => {
|
|
19
|
+
const {
|
|
20
|
+
web3Auth
|
|
21
|
+
} = useWeb3AuthInner.useWeb3AuthInner();
|
|
22
|
+
const loading = vue.ref(false);
|
|
23
|
+
const error = vue.ref(null);
|
|
24
|
+
const enableMFA = async () => {
|
|
25
|
+
try {
|
|
26
|
+
if (!web3Auth.value) throw index.WalletInitializationError.notReady();
|
|
27
|
+
error.value = null;
|
|
28
|
+
loading.value = true;
|
|
29
|
+
await web3Auth.value.enableMFA();
|
|
30
|
+
} catch (err) {
|
|
31
|
+
error.value = err;
|
|
32
|
+
} finally {
|
|
33
|
+
loading.value = false;
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
return {
|
|
37
|
+
loading,
|
|
38
|
+
error,
|
|
39
|
+
enableMFA
|
|
40
|
+
};
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
exports.useEnableMFA = useEnableMFA;
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var vue = require('vue');
|
|
4
|
+
require('@toruslabs/base-controllers');
|
|
5
|
+
require('@babel/runtime/helpers/defineProperty');
|
|
6
|
+
require('@web3auth/auth');
|
|
7
|
+
var index = require('../../base/errors/index.js');
|
|
8
|
+
require('../../base/wallet/index.js');
|
|
9
|
+
require('../../base/connector/constants.js');
|
|
10
|
+
require('jwt-decode');
|
|
11
|
+
require('../../base/loglevel.js');
|
|
12
|
+
require('../../base/plugin/errors.js');
|
|
13
|
+
require('../../base/plugin/IPlugin.js');
|
|
14
|
+
require('@toruslabs/constants');
|
|
15
|
+
require('@toruslabs/http-helpers');
|
|
16
|
+
var useWeb3AuthInner = require('./useWeb3AuthInner.js');
|
|
17
|
+
|
|
18
|
+
const useIdentityToken = () => {
|
|
19
|
+
const {
|
|
20
|
+
web3Auth,
|
|
21
|
+
isConnected
|
|
22
|
+
} = useWeb3AuthInner.useWeb3AuthInner();
|
|
23
|
+
const loading = vue.ref(false);
|
|
24
|
+
const error = vue.ref(null);
|
|
25
|
+
const token = vue.ref(null);
|
|
26
|
+
const authenticateUser = async () => {
|
|
27
|
+
try {
|
|
28
|
+
if (!web3Auth.value) throw index.WalletInitializationError.notReady();
|
|
29
|
+
error.value = null;
|
|
30
|
+
loading.value = true;
|
|
31
|
+
const result = await web3Auth.value.authenticateUser();
|
|
32
|
+
if (result !== null && result !== void 0 && result.idToken) {
|
|
33
|
+
token.value = result.idToken;
|
|
34
|
+
}
|
|
35
|
+
return result === null || result === void 0 ? void 0 : result.idToken;
|
|
36
|
+
} catch (err) {
|
|
37
|
+
error.value = err;
|
|
38
|
+
} finally {
|
|
39
|
+
loading.value = false;
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
vue.watch(isConnected, newIsConnected => {
|
|
43
|
+
if (!newIsConnected && token.value) {
|
|
44
|
+
token.value = null;
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
return {
|
|
48
|
+
loading,
|
|
49
|
+
error,
|
|
50
|
+
token,
|
|
51
|
+
authenticateUser
|
|
52
|
+
};
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
exports.useIdentityToken = useIdentityToken;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var vue = require('vue');
|
|
4
|
+
require('@toruslabs/base-controllers');
|
|
5
|
+
require('@babel/runtime/helpers/defineProperty');
|
|
6
|
+
require('@web3auth/auth');
|
|
7
|
+
var index = require('../../base/errors/index.js');
|
|
8
|
+
require('../../base/wallet/index.js');
|
|
9
|
+
require('../../base/connector/constants.js');
|
|
10
|
+
require('jwt-decode');
|
|
11
|
+
require('../../base/loglevel.js');
|
|
12
|
+
require('../../base/plugin/errors.js');
|
|
13
|
+
require('../../base/plugin/IPlugin.js');
|
|
14
|
+
require('@toruslabs/constants');
|
|
15
|
+
require('@toruslabs/http-helpers');
|
|
16
|
+
var useWeb3AuthInner = require('./useWeb3AuthInner.js');
|
|
17
|
+
|
|
18
|
+
const useManageMFA = () => {
|
|
19
|
+
const {
|
|
20
|
+
web3Auth
|
|
21
|
+
} = useWeb3AuthInner.useWeb3AuthInner();
|
|
22
|
+
const loading = vue.ref(false);
|
|
23
|
+
const error = vue.ref(null);
|
|
24
|
+
const manageMFA = async () => {
|
|
25
|
+
try {
|
|
26
|
+
if (!web3Auth.value) throw index.WalletInitializationError.notReady();
|
|
27
|
+
error.value = null;
|
|
28
|
+
loading.value = true;
|
|
29
|
+
await web3Auth.value.enableMFA();
|
|
30
|
+
} catch (err) {
|
|
31
|
+
error.value = err;
|
|
32
|
+
} finally {
|
|
33
|
+
loading.value = false;
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
return {
|
|
37
|
+
loading,
|
|
38
|
+
error,
|
|
39
|
+
manageMFA
|
|
40
|
+
};
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
exports.useManageMFA = useManageMFA;
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var vue = require('vue');
|
|
4
|
+
require('@toruslabs/base-controllers');
|
|
5
|
+
require('@babel/runtime/helpers/defineProperty');
|
|
6
|
+
require('@web3auth/auth');
|
|
7
|
+
require('../../base/errors/index.js');
|
|
8
|
+
require('../../base/wallet/index.js');
|
|
9
|
+
require('../../base/connector/constants.js');
|
|
10
|
+
require('jwt-decode');
|
|
11
|
+
require('../../base/loglevel.js');
|
|
12
|
+
var errors = require('../../base/plugin/errors.js');
|
|
13
|
+
require('../../base/plugin/IPlugin.js');
|
|
14
|
+
require('@toruslabs/constants');
|
|
15
|
+
require('@toruslabs/http-helpers');
|
|
16
|
+
var useWalletServicesPlugin = require('./useWalletServicesPlugin.js');
|
|
17
|
+
|
|
18
|
+
const useSwap = () => {
|
|
19
|
+
const {
|
|
20
|
+
plugin,
|
|
21
|
+
ready
|
|
22
|
+
} = useWalletServicesPlugin.useWalletServicesPlugin();
|
|
23
|
+
const loading = vue.ref(false);
|
|
24
|
+
const error = vue.ref(null);
|
|
25
|
+
const showSwap = async showSwapParams => {
|
|
26
|
+
loading.value = true;
|
|
27
|
+
error.value = null;
|
|
28
|
+
try {
|
|
29
|
+
if (!plugin) throw errors.WalletServicesPluginError.notInitialized();
|
|
30
|
+
if (!ready) throw errors.WalletServicesPluginError.walletPluginNotConnected();
|
|
31
|
+
await plugin.value.showSwap(showSwapParams);
|
|
32
|
+
} catch (err) {
|
|
33
|
+
error.value = err;
|
|
34
|
+
} finally {
|
|
35
|
+
loading.value = false;
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
return {
|
|
39
|
+
loading,
|
|
40
|
+
error,
|
|
41
|
+
showSwap
|
|
42
|
+
};
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
exports.useSwap = useSwap;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var vue = require('vue');
|
|
4
|
+
require('@toruslabs/base-controllers');
|
|
5
|
+
require('@babel/runtime/helpers/defineProperty');
|
|
6
|
+
require('@web3auth/auth');
|
|
7
|
+
var index = require('../../base/errors/index.js');
|
|
8
|
+
require('../../base/wallet/index.js');
|
|
9
|
+
require('../../base/connector/constants.js');
|
|
10
|
+
require('jwt-decode');
|
|
11
|
+
require('../../base/loglevel.js');
|
|
12
|
+
require('../../base/plugin/errors.js');
|
|
13
|
+
require('../../base/plugin/IPlugin.js');
|
|
14
|
+
require('@toruslabs/constants');
|
|
15
|
+
require('@toruslabs/http-helpers');
|
|
16
|
+
var useWeb3AuthInner = require('./useWeb3AuthInner.js');
|
|
17
|
+
|
|
18
|
+
const useSwitchChain = () => {
|
|
19
|
+
const {
|
|
20
|
+
web3Auth
|
|
21
|
+
} = useWeb3AuthInner.useWeb3AuthInner();
|
|
22
|
+
const loading = vue.ref(false);
|
|
23
|
+
const error = vue.ref(null);
|
|
24
|
+
const switchChain = async chainParams => {
|
|
25
|
+
try {
|
|
26
|
+
if (!web3Auth.value) throw index.WalletInitializationError.notReady();
|
|
27
|
+
error.value = null;
|
|
28
|
+
loading.value = true;
|
|
29
|
+
await web3Auth.value.switchChain(chainParams);
|
|
30
|
+
} catch (err) {
|
|
31
|
+
error.value = err;
|
|
32
|
+
} finally {
|
|
33
|
+
loading.value = false;
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
return {
|
|
37
|
+
loading,
|
|
38
|
+
error,
|
|
39
|
+
switchChain
|
|
40
|
+
};
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
exports.useSwitchChain = useSwitchChain;
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var vue = require('vue');
|
|
4
|
+
require('@toruslabs/base-controllers');
|
|
5
|
+
require('@babel/runtime/helpers/defineProperty');
|
|
6
|
+
require('@web3auth/auth');
|
|
7
|
+
require('../../base/errors/index.js');
|
|
8
|
+
require('../../base/wallet/index.js');
|
|
9
|
+
require('../../base/connector/constants.js');
|
|
10
|
+
require('jwt-decode');
|
|
11
|
+
require('../../base/loglevel.js');
|
|
12
|
+
var errors = require('../../base/plugin/errors.js');
|
|
13
|
+
require('../../base/plugin/IPlugin.js');
|
|
14
|
+
require('@toruslabs/constants');
|
|
15
|
+
require('@toruslabs/http-helpers');
|
|
16
|
+
var useWalletServicesPlugin = require('./useWalletServicesPlugin.js');
|
|
17
|
+
|
|
18
|
+
const useWalletConnectScanner = () => {
|
|
19
|
+
const {
|
|
20
|
+
plugin,
|
|
21
|
+
ready
|
|
22
|
+
} = useWalletServicesPlugin.useWalletServicesPlugin();
|
|
23
|
+
const loading = vue.ref(false);
|
|
24
|
+
const error = vue.ref(null);
|
|
25
|
+
const showWalletConnectScanner = async showWalletConnectScannerParams => {
|
|
26
|
+
loading.value = true;
|
|
27
|
+
error.value = null;
|
|
28
|
+
try {
|
|
29
|
+
if (!plugin) throw errors.WalletServicesPluginError.notInitialized();
|
|
30
|
+
if (!ready) throw errors.WalletServicesPluginError.walletPluginNotConnected();
|
|
31
|
+
await plugin.value.showWalletConnectScanner(showWalletConnectScannerParams);
|
|
32
|
+
} catch (err) {
|
|
33
|
+
error.value = err;
|
|
34
|
+
} finally {
|
|
35
|
+
loading.value = false;
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
return {
|
|
39
|
+
loading,
|
|
40
|
+
error,
|
|
41
|
+
showWalletConnectScanner
|
|
42
|
+
};
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
exports.useWalletConnectScanner = useWalletConnectScanner;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var vue = require('vue');
|
|
4
|
+
var WalletServicesContext = require('../context/WalletServicesContext.js');
|
|
5
|
+
|
|
6
|
+
const useWalletServicesPlugin = () => {
|
|
7
|
+
const context = vue.inject(WalletServicesContext.WalletServicesContextKey);
|
|
8
|
+
if (!context) throw new Error("WalletServicesContext not found");
|
|
9
|
+
return context;
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
exports.useWalletServicesPlugin = useWalletServicesPlugin;
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var vue = require('vue');
|
|
4
|
+
require('@toruslabs/base-controllers');
|
|
5
|
+
require('@babel/runtime/helpers/defineProperty');
|
|
6
|
+
require('@web3auth/auth');
|
|
7
|
+
require('../../base/errors/index.js');
|
|
8
|
+
require('../../base/wallet/index.js');
|
|
9
|
+
require('../../base/connector/constants.js');
|
|
10
|
+
require('jwt-decode');
|
|
11
|
+
require('../../base/loglevel.js');
|
|
12
|
+
var errors = require('../../base/plugin/errors.js');
|
|
13
|
+
require('../../base/plugin/IPlugin.js');
|
|
14
|
+
require('@toruslabs/constants');
|
|
15
|
+
require('@toruslabs/http-helpers');
|
|
16
|
+
var useWalletServicesPlugin = require('./useWalletServicesPlugin.js');
|
|
17
|
+
|
|
18
|
+
const useWalletUI = () => {
|
|
19
|
+
const {
|
|
20
|
+
plugin,
|
|
21
|
+
ready
|
|
22
|
+
} = useWalletServicesPlugin.useWalletServicesPlugin();
|
|
23
|
+
const loading = vue.ref(false);
|
|
24
|
+
const error = vue.ref(null);
|
|
25
|
+
const showWalletUI = async showWalletUiParams => {
|
|
26
|
+
loading.value = true;
|
|
27
|
+
error.value = null;
|
|
28
|
+
try {
|
|
29
|
+
if (!plugin) throw errors.WalletServicesPluginError.notInitialized();
|
|
30
|
+
if (!ready) throw errors.WalletServicesPluginError.walletPluginNotConnected();
|
|
31
|
+
await plugin.value.showWalletUi(showWalletUiParams);
|
|
32
|
+
} catch (err) {
|
|
33
|
+
error.value = err;
|
|
34
|
+
} finally {
|
|
35
|
+
loading.value = false;
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
return {
|
|
39
|
+
loading,
|
|
40
|
+
error,
|
|
41
|
+
showWalletUI
|
|
42
|
+
};
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
exports.useWalletUI = useWalletUI;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var useWeb3AuthInner = require('./useWeb3AuthInner.js');
|
|
4
|
+
|
|
5
|
+
const useWeb3Auth = () => {
|
|
6
|
+
const {
|
|
7
|
+
initError,
|
|
8
|
+
isConnected,
|
|
9
|
+
isInitialized,
|
|
10
|
+
isInitializing,
|
|
11
|
+
provider,
|
|
12
|
+
status,
|
|
13
|
+
web3Auth,
|
|
14
|
+
getPlugin
|
|
15
|
+
} = useWeb3AuthInner.useWeb3AuthInner();
|
|
16
|
+
return {
|
|
17
|
+
initError,
|
|
18
|
+
isConnected,
|
|
19
|
+
isInitialized,
|
|
20
|
+
isInitializing,
|
|
21
|
+
provider,
|
|
22
|
+
status,
|
|
23
|
+
web3Auth,
|
|
24
|
+
getPlugin
|
|
25
|
+
};
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
exports.useWeb3Auth = useWeb3Auth;
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var vue = require('vue');
|
|
4
|
+
require('@toruslabs/base-controllers');
|
|
5
|
+
require('@babel/runtime/helpers/defineProperty');
|
|
6
|
+
require('@web3auth/auth');
|
|
7
|
+
var index = require('../../base/errors/index.js');
|
|
8
|
+
require('../../base/wallet/index.js');
|
|
9
|
+
require('../../base/connector/constants.js');
|
|
10
|
+
require('jwt-decode');
|
|
11
|
+
require('../../base/loglevel.js');
|
|
12
|
+
require('../../base/plugin/errors.js');
|
|
13
|
+
require('../../base/plugin/IPlugin.js');
|
|
14
|
+
require('@toruslabs/constants');
|
|
15
|
+
require('@toruslabs/http-helpers');
|
|
16
|
+
var useWeb3AuthInner = require('./useWeb3AuthInner.js');
|
|
17
|
+
|
|
18
|
+
const useWeb3AuthConnect = () => {
|
|
19
|
+
const {
|
|
20
|
+
web3Auth,
|
|
21
|
+
isConnected
|
|
22
|
+
} = useWeb3AuthInner.useWeb3AuthInner();
|
|
23
|
+
const loading = vue.ref(false);
|
|
24
|
+
const error = vue.ref(null);
|
|
25
|
+
const connectorName = vue.ref(null);
|
|
26
|
+
vue.watch(isConnected, newVal => {
|
|
27
|
+
if (!newVal && connectorName.value) {
|
|
28
|
+
connectorName.value = null;
|
|
29
|
+
}
|
|
30
|
+
}, {
|
|
31
|
+
immediate: true
|
|
32
|
+
});
|
|
33
|
+
const connect = async (connectorType, loginParams) => {
|
|
34
|
+
try {
|
|
35
|
+
if (!web3Auth.value) throw index.WalletInitializationError.notReady();
|
|
36
|
+
error.value = null;
|
|
37
|
+
loading.value = true;
|
|
38
|
+
const localProvider = await web3Auth.value.connectTo(connectorType, loginParams);
|
|
39
|
+
connectorName.value = web3Auth.value.connectedConnectorName;
|
|
40
|
+
return localProvider;
|
|
41
|
+
} catch (err) {
|
|
42
|
+
error.value = err;
|
|
43
|
+
return null;
|
|
44
|
+
} finally {
|
|
45
|
+
loading.value = false;
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
return {
|
|
49
|
+
isConnected,
|
|
50
|
+
loading,
|
|
51
|
+
error,
|
|
52
|
+
connectorName,
|
|
53
|
+
connect
|
|
54
|
+
};
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
exports.useWeb3AuthConnect = useWeb3AuthConnect;
|