@reown/appkit-siwe 1.4.1 → 1.5.1
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/esm/core/controller/SIWEController.js +0 -5
- package/dist/esm/core/controller/SIWEController.js.map +1 -1
- package/dist/esm/exports/index.js +1 -0
- package/dist/esm/exports/index.js.map +1 -1
- package/dist/esm/scaffold/views/w3m-connecting-siwe-view/index.js +4 -4
- package/dist/esm/src/mapToSIWX.js +139 -0
- package/dist/esm/src/mapToSIWX.js.map +1 -0
- package/dist/esm/tsconfig.tsbuildinfo +1 -1
- package/dist/types/exports/index.d.ts +1 -0
- package/dist/types/src/mapToSIWX.d.ts +3 -0
- package/package.json +7 -7
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { subscribeKey as subKey } from 'valtio/vanilla/utils';
|
|
2
2
|
import { proxy, ref, subscribe as sub } from 'valtio/vanilla';
|
|
3
|
-
import { ChainController, OptionsController } from '@reown/appkit-core';
|
|
4
3
|
const state = proxy({
|
|
5
4
|
status: 'uninitialized'
|
|
6
5
|
});
|
|
@@ -73,15 +72,12 @@ export const SIWEController = {
|
|
|
73
72
|
state._client = ref(client);
|
|
74
73
|
state.session = await this.getSession();
|
|
75
74
|
state.status = state.session ? 'success' : 'ready';
|
|
76
|
-
ChainController.setAccountProp('siweStatus', state.status, 'eip155');
|
|
77
|
-
OptionsController.setIsSiweEnabled(client.options.enabled);
|
|
78
75
|
},
|
|
79
76
|
setNonce(nonce) {
|
|
80
77
|
state.nonce = nonce;
|
|
81
78
|
},
|
|
82
79
|
setStatus(status) {
|
|
83
80
|
state.status = status;
|
|
84
|
-
ChainController.setAccountProp('siweStatus', state.status, 'eip155');
|
|
85
81
|
},
|
|
86
82
|
setMessage(message) {
|
|
87
83
|
state.message = message;
|
|
@@ -89,7 +85,6 @@ export const SIWEController = {
|
|
|
89
85
|
setSession(session) {
|
|
90
86
|
state.session = session;
|
|
91
87
|
state.status = session ? 'success' : 'ready';
|
|
92
|
-
ChainController.setAccountProp('siweStatus', state.status, 'eip155');
|
|
93
88
|
}
|
|
94
89
|
};
|
|
95
90
|
//# sourceMappingURL=SIWEController.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SIWEController.js","sourceRoot":"","sources":["../../../../core/controller/SIWEController.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,IAAI,MAAM,EAAE,MAAM,sBAAsB,CAAA;AAC7D,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,SAAS,IAAI,GAAG,EAAE,MAAM,gBAAgB,CAAA;
|
|
1
|
+
{"version":3,"file":"SIWEController.js","sourceRoot":"","sources":["../../../../core/controller/SIWEController.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../exports/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAA;AACnD,OAAO,EACL,qBAAqB,EACrB,qBAAqB,EACrB,eAAe,EAChB,MAAM,0BAA0B,CAAA;AACjC,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AAClF,OAAO,EAAE,cAAc,EAA6B,MAAM,sCAAsC,CAAA;AAChG,cAAc,4BAA4B,CAAA;AAI1C,MAAM,UAAU,gBAAgB,CAAC,UAAsB;IACrD,OAAO,IAAI,gBAAgB,CAAC,UAAU,CAAC,CAAA;AACzC,CAAC;AAED,cAAc,mDAAmD,CAAA;AACjE,cAAc,qDAAqD,CAAA"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../exports/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAA;AACnD,OAAO,EACL,qBAAqB,EACrB,qBAAqB,EACrB,eAAe,EAChB,MAAM,0BAA0B,CAAA;AACjC,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AAClF,OAAO,EAAE,cAAc,EAA6B,MAAM,sCAAsC,CAAA;AAChG,cAAc,4BAA4B,CAAA;AAI1C,MAAM,UAAU,gBAAgB,CAAC,UAAsB;IACrD,OAAO,IAAI,gBAAgB,CAAC,UAAU,CAAC,CAAA;AACzC,CAAC;AAED,cAAc,mDAAmD,CAAA;AACjE,cAAc,qDAAqD,CAAA;AACnE,cAAc,qBAAqB,CAAA"}
|
|
@@ -70,7 +70,7 @@ let W3mConnectingSiweView = class W3mConnectingSiweView extends LitElement {
|
|
|
70
70
|
async onSign() {
|
|
71
71
|
this.isSigning = true;
|
|
72
72
|
EventsController.sendEvent({
|
|
73
|
-
event: '
|
|
73
|
+
event: 'CLICK_SIGN_SIWX_MESSAGE',
|
|
74
74
|
type: 'track',
|
|
75
75
|
properties: {
|
|
76
76
|
network: ChainController.state.activeCaipNetwork?.caipNetworkId || '',
|
|
@@ -83,7 +83,7 @@ let W3mConnectingSiweView = class W3mConnectingSiweView extends LitElement {
|
|
|
83
83
|
const session = await SIWEController.signIn();
|
|
84
84
|
SIWEController.setStatus('success');
|
|
85
85
|
EventsController.sendEvent({
|
|
86
|
-
event: '
|
|
86
|
+
event: 'SIWX_AUTH_SUCCESS',
|
|
87
87
|
type: 'track',
|
|
88
88
|
properties: {
|
|
89
89
|
network: ChainController.state.activeCaipNetwork?.caipNetworkId || '',
|
|
@@ -104,7 +104,7 @@ let W3mConnectingSiweView = class W3mConnectingSiweView extends LitElement {
|
|
|
104
104
|
}
|
|
105
105
|
SIWEController.setStatus('error');
|
|
106
106
|
return EventsController.sendEvent({
|
|
107
|
-
event: '
|
|
107
|
+
event: 'SIWX_AUTH_ERROR',
|
|
108
108
|
type: 'track',
|
|
109
109
|
properties: {
|
|
110
110
|
network: ChainController.state.activeCaipNetwork?.caipNetworkId || '',
|
|
@@ -128,7 +128,7 @@ let W3mConnectingSiweView = class W3mConnectingSiweView extends LitElement {
|
|
|
128
128
|
}
|
|
129
129
|
this.isCancelling = false;
|
|
130
130
|
EventsController.sendEvent({
|
|
131
|
-
event: '
|
|
131
|
+
event: 'CLICK_CANCEL_SIWX',
|
|
132
132
|
type: 'track',
|
|
133
133
|
properties: {
|
|
134
134
|
network: ChainController.state.activeCaipNetwork?.caipNetworkId || '',
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
import { ChainController, CoreHelperUtil } from '@reown/appkit-core';
|
|
2
|
+
import { NetworkUtil } from '@reown/appkit-common';
|
|
3
|
+
export function mapToSIWX(siwe) {
|
|
4
|
+
async function getSession() {
|
|
5
|
+
try {
|
|
6
|
+
return await siwe.methods.getSession();
|
|
7
|
+
}
|
|
8
|
+
catch (error) {
|
|
9
|
+
console.warn('AppKit:SIWE:getSession - error:', error);
|
|
10
|
+
return undefined;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
ChainController.subscribeKey('activeCaipNetwork', async (activeCaipNetwork) => {
|
|
14
|
+
if (!siwe.options.signOutOnNetworkChange) {
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
const session = await getSession();
|
|
18
|
+
const isDiffernetNetwork = session &&
|
|
19
|
+
session.chainId !== NetworkUtil.caipNetworkIdToNumber(activeCaipNetwork?.caipNetworkId);
|
|
20
|
+
if (isDiffernetNetwork) {
|
|
21
|
+
await siwe.methods.signOut();
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
ChainController.subscribeKey('activeCaipAddress', async (activeCaipAddress) => {
|
|
25
|
+
if (!siwe.options.signOutOnAccountChange) {
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
const session = await getSession();
|
|
29
|
+
const isDifferentAddress = session && session.address !== CoreHelperUtil.getPlainAddress(activeCaipAddress);
|
|
30
|
+
if (isDifferentAddress) {
|
|
31
|
+
await siwe.methods.signOut();
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
return {
|
|
35
|
+
async createMessage(input) {
|
|
36
|
+
const params = await siwe.methods.getMessageParams?.();
|
|
37
|
+
if (!params) {
|
|
38
|
+
throw new Error('Failed to get message params!');
|
|
39
|
+
}
|
|
40
|
+
const nonce = await siwe.getNonce(input.accountAddress);
|
|
41
|
+
const issuedAt = params.iat || new Date().toISOString();
|
|
42
|
+
const version = '1';
|
|
43
|
+
return {
|
|
44
|
+
nonce,
|
|
45
|
+
version,
|
|
46
|
+
requestId: params.requestId,
|
|
47
|
+
accountAddress: input.accountAddress,
|
|
48
|
+
chainId: input.chainId,
|
|
49
|
+
domain: params.domain,
|
|
50
|
+
uri: params.uri,
|
|
51
|
+
notBefore: params.nbf,
|
|
52
|
+
resources: params.resources,
|
|
53
|
+
statement: params.statement,
|
|
54
|
+
expirationTime: params.exp,
|
|
55
|
+
issuedAt,
|
|
56
|
+
toString: () => siwe.createMessage({
|
|
57
|
+
...params,
|
|
58
|
+
chainId: NetworkUtil.caipNetworkIdToNumber(input.chainId) || 1,
|
|
59
|
+
address: `did:pkh:${input.chainId}:${input.accountAddress}`,
|
|
60
|
+
nonce,
|
|
61
|
+
version,
|
|
62
|
+
iat: issuedAt
|
|
63
|
+
})
|
|
64
|
+
};
|
|
65
|
+
},
|
|
66
|
+
async addSession(session) {
|
|
67
|
+
const chainId = NetworkUtil.parseEvmChainId(session.data.chainId);
|
|
68
|
+
if (!chainId) {
|
|
69
|
+
return Promise.resolve();
|
|
70
|
+
}
|
|
71
|
+
if (await siwe.methods.verifyMessage(session)) {
|
|
72
|
+
siwe.methods.onSignIn?.({
|
|
73
|
+
address: session.data.accountAddress,
|
|
74
|
+
chainId: NetworkUtil.parseEvmChainId(session.data.chainId)
|
|
75
|
+
});
|
|
76
|
+
return Promise.resolve();
|
|
77
|
+
}
|
|
78
|
+
throw new Error('Failed to add session');
|
|
79
|
+
},
|
|
80
|
+
async revokeSession(_chainId, _address) {
|
|
81
|
+
try {
|
|
82
|
+
await siwe.methods.signOut();
|
|
83
|
+
siwe.methods.onSignOut?.();
|
|
84
|
+
}
|
|
85
|
+
catch (error) {
|
|
86
|
+
console.warn('AppKit:SIWE:revokeSession - signOut error', error);
|
|
87
|
+
}
|
|
88
|
+
},
|
|
89
|
+
async setSessions(sessions) {
|
|
90
|
+
if (sessions.length === 0) {
|
|
91
|
+
try {
|
|
92
|
+
await siwe.methods.signOut();
|
|
93
|
+
}
|
|
94
|
+
catch (error) {
|
|
95
|
+
console.warn('AppKit:SIWE:setSessions - signOut error', error);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
const addingSessions = sessions.map(session => this.addSession(session));
|
|
100
|
+
await Promise.all(addingSessions);
|
|
101
|
+
}
|
|
102
|
+
},
|
|
103
|
+
async getSessions(chainId, address) {
|
|
104
|
+
try {
|
|
105
|
+
if (!chainId.startsWith('eip155:')) {
|
|
106
|
+
return [
|
|
107
|
+
{
|
|
108
|
+
data: {
|
|
109
|
+
accountAddress: address,
|
|
110
|
+
chainId
|
|
111
|
+
},
|
|
112
|
+
message: '',
|
|
113
|
+
signature: ''
|
|
114
|
+
}
|
|
115
|
+
];
|
|
116
|
+
}
|
|
117
|
+
const siweSession = await getSession();
|
|
118
|
+
const siweCaipNetworkId = `eip155:${siweSession?.chainId}`;
|
|
119
|
+
if (!siweSession || siweSession.address !== address || siweCaipNetworkId !== chainId) {
|
|
120
|
+
return [];
|
|
121
|
+
}
|
|
122
|
+
const session = {
|
|
123
|
+
data: {
|
|
124
|
+
accountAddress: siweSession.address,
|
|
125
|
+
chainId: siweCaipNetworkId
|
|
126
|
+
},
|
|
127
|
+
message: '',
|
|
128
|
+
signature: ''
|
|
129
|
+
};
|
|
130
|
+
return [session];
|
|
131
|
+
}
|
|
132
|
+
catch (error) {
|
|
133
|
+
console.warn('AppKit:SIWE:getSessions - error:', error);
|
|
134
|
+
return [];
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
};
|
|
138
|
+
}
|
|
139
|
+
//# sourceMappingURL=mapToSIWX.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mapToSIWX.js","sourceRoot":"","sources":["../../../src/mapToSIWX.ts"],"names":[],"mappings":"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"}
|