@haneullabs/enoki 0.1.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/CHANGELOG.md +1109 -0
- package/README.md +1 -0
- package/dist/cjs/EnokiClient/index.d.ts +36 -0
- package/dist/cjs/EnokiClient/index.js +196 -0
- package/dist/cjs/EnokiClient/index.js.map +7 -0
- package/dist/cjs/EnokiClient/type.d.ts +119 -0
- package/dist/cjs/EnokiClient/type.js +17 -0
- package/dist/cjs/EnokiClient/type.js.map +7 -0
- package/dist/cjs/EnokiFlow.d.ts +74 -0
- package/dist/cjs/EnokiFlow.js +279 -0
- package/dist/cjs/EnokiFlow.js.map +7 -0
- package/dist/cjs/EnokiKeypair.d.ts +20 -0
- package/dist/cjs/EnokiKeypair.js +87 -0
- package/dist/cjs/EnokiKeypair.js.map +7 -0
- package/dist/cjs/encryption.d.ts +15 -0
- package/dist/cjs/encryption.js +96 -0
- package/dist/cjs/encryption.js.map +7 -0
- package/dist/cjs/index.d.ts +12 -0
- package/dist/cjs/index.js +50 -0
- package/dist/cjs/index.js.map +7 -0
- package/dist/cjs/package.json +4 -0
- package/dist/cjs/react.d.ts +20 -0
- package/dist/cjs/react.js +76 -0
- package/dist/cjs/react.js.map +7 -0
- package/dist/cjs/stores.d.ts +21 -0
- package/dist/cjs/stores.js +67 -0
- package/dist/cjs/stores.js.map +7 -0
- package/dist/cjs/utils.d.ts +2 -0
- package/dist/cjs/utils.js +27 -0
- package/dist/cjs/utils.js.map +7 -0
- package/dist/cjs/wallet/features.d.ts +50 -0
- package/dist/cjs/wallet/features.js +27 -0
- package/dist/cjs/wallet/features.js.map +7 -0
- package/dist/cjs/wallet/initializer.d.ts +11 -0
- package/dist/cjs/wallet/initializer.js +41 -0
- package/dist/cjs/wallet/initializer.js.map +7 -0
- package/dist/cjs/wallet/providers.d.ts +7 -0
- package/dist/cjs/wallet/providers.js +51 -0
- package/dist/cjs/wallet/providers.js.map +7 -0
- package/dist/cjs/wallet/register.d.ts +7 -0
- package/dist/cjs/wallet/register.js +68 -0
- package/dist/cjs/wallet/register.js.map +7 -0
- package/dist/cjs/wallet/state.d.ts +18 -0
- package/dist/cjs/wallet/state.js +142 -0
- package/dist/cjs/wallet/state.js.map +7 -0
- package/dist/cjs/wallet/types.d.ts +82 -0
- package/dist/cjs/wallet/types.js +17 -0
- package/dist/cjs/wallet/types.js.map +7 -0
- package/dist/cjs/wallet/utils.d.ts +11 -0
- package/dist/cjs/wallet/utils.js +83 -0
- package/dist/cjs/wallet/utils.js.map +7 -0
- package/dist/cjs/wallet/wallet.d.ts +16 -0
- package/dist/cjs/wallet/wallet.js +466 -0
- package/dist/cjs/wallet/wallet.js.map +7 -0
- package/dist/esm/EnokiClient/index.d.ts +36 -0
- package/dist/esm/EnokiClient/index.js +176 -0
- package/dist/esm/EnokiClient/index.js.map +7 -0
- package/dist/esm/EnokiClient/type.d.ts +119 -0
- package/dist/esm/EnokiClient/type.js +1 -0
- package/dist/esm/EnokiClient/type.js.map +7 -0
- package/dist/esm/EnokiFlow.d.ts +74 -0
- package/dist/esm/EnokiFlow.js +259 -0
- package/dist/esm/EnokiFlow.js.map +7 -0
- package/dist/esm/EnokiKeypair.d.ts +20 -0
- package/dist/esm/EnokiKeypair.js +67 -0
- package/dist/esm/EnokiKeypair.js.map +7 -0
- package/dist/esm/encryption.d.ts +15 -0
- package/dist/esm/encryption.js +76 -0
- package/dist/esm/encryption.js.map +7 -0
- package/dist/esm/index.d.ts +12 -0
- package/dist/esm/index.js +41 -0
- package/dist/esm/index.js.map +7 -0
- package/dist/esm/package.json +4 -0
- package/dist/esm/react.d.ts +20 -0
- package/dist/esm/react.js +56 -0
- package/dist/esm/react.js.map +7 -0
- package/dist/esm/stores.d.ts +21 -0
- package/dist/esm/stores.js +47 -0
- package/dist/esm/stores.js.map +7 -0
- package/dist/esm/utils.d.ts +2 -0
- package/dist/esm/utils.js +7 -0
- package/dist/esm/utils.js.map +7 -0
- package/dist/esm/wallet/features.d.ts +50 -0
- package/dist/esm/wallet/features.js +7 -0
- package/dist/esm/wallet/features.js.map +7 -0
- package/dist/esm/wallet/initializer.d.ts +11 -0
- package/dist/esm/wallet/initializer.js +21 -0
- package/dist/esm/wallet/initializer.js.map +7 -0
- package/dist/esm/wallet/providers.d.ts +7 -0
- package/dist/esm/wallet/providers.js +31 -0
- package/dist/esm/wallet/providers.js.map +7 -0
- package/dist/esm/wallet/register.d.ts +7 -0
- package/dist/esm/wallet/register.js +48 -0
- package/dist/esm/wallet/register.js.map +7 -0
- package/dist/esm/wallet/state.d.ts +18 -0
- package/dist/esm/wallet/state.js +122 -0
- package/dist/esm/wallet/state.js.map +7 -0
- package/dist/esm/wallet/types.d.ts +82 -0
- package/dist/esm/wallet/types.js +1 -0
- package/dist/esm/wallet/types.js.map +7 -0
- package/dist/esm/wallet/utils.d.ts +11 -0
- package/dist/esm/wallet/utils.js +63 -0
- package/dist/esm/wallet/utils.js.map +7 -0
- package/dist/esm/wallet/wallet.d.ts +16 -0
- package/dist/esm/wallet/wallet.js +444 -0
- package/dist/esm/wallet/wallet.js.map +7 -0
- package/dist/tsconfig.esm.tsbuildinfo +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +80 -0
- package/react/package.json +5 -0
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/wallet/initializer.ts"],
|
|
4
|
+
"sourcesContent": ["// Copyright (c) Mysten Labs, Inc.\n// SPDX-License-Identifier: Apache-2.0\n\nimport type { ClientWithCoreApi, Experimental_HaneulClientTypes } from '@haneullabs/haneul/experimental';\nimport { registerEnokiWallets } from './register.js';\nimport type { RegisterEnokiWalletsOptions } from './types.js';\n\nexport function enokiWalletsInitializer(\n\toptions: Omit<RegisterEnokiWalletsOptions, 'clients' | 'getCurrentNetwork'>,\n) {\n\treturn {\n\t\tid: 'enoki-wallets-initializer',\n\t\tasync initialize({\n\t\t\tnetworks,\n\t\t\tgetClient,\n\t\t}: {\n\t\t\tnetworks: readonly Experimental_HaneulClientTypes.Network[];\n\t\t\tgetClient: (network?: Experimental_HaneulClientTypes.Network) => ClientWithCoreApi;\n\t\t}) {\n\t\t\tconst { unregister } = registerEnokiWallets({\n\t\t\t\t...options,\n\t\t\t\tgetCurrentNetwork: () => getClient().network,\n\t\t\t\tclients: networks.map(getClient),\n\t\t\t});\n\n\t\t\treturn { unregister };\n\t\t},\n\t};\n}\n"],
|
|
5
|
+
"mappings": "AAIA,SAAS,4BAA4B;AAG9B,SAAS,wBACf,SACC;AACD,SAAO;AAAA,IACN,IAAI;AAAA,IACJ,MAAM,WAAW;AAAA,MAChB;AAAA,MACA;AAAA,IACD,GAGG;AACF,YAAM,EAAE,WAAW,IAAI,qBAAqB;AAAA,QAC3C,GAAG;AAAA,QACH,mBAAmB,MAAM,UAAU,EAAE;AAAA,QACrC,SAAS,SAAS,IAAI,SAAS;AAAA,MAChC,CAAC;AAED,aAAO,EAAE,WAAW;AAAA,IACrB;AAAA,EACD;AACD;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
const ENOKI_PROVIDER_WALLETS_INFO = [
|
|
2
|
+
{
|
|
3
|
+
provider: "google",
|
|
4
|
+
name: "Sign in with Google",
|
|
5
|
+
icon: ""
|
|
6
|
+
},
|
|
7
|
+
{
|
|
8
|
+
provider: "facebook",
|
|
9
|
+
name: "Sign in with Facebook",
|
|
10
|
+
icon: ""
|
|
11
|
+
},
|
|
12
|
+
{
|
|
13
|
+
provider: "twitch",
|
|
14
|
+
name: "Sign in with Twitch",
|
|
15
|
+
icon: ""
|
|
16
|
+
},
|
|
17
|
+
{
|
|
18
|
+
provider: "onefc",
|
|
19
|
+
name: "Sign in with ONE Championship",
|
|
20
|
+
icon: ""
|
|
21
|
+
},
|
|
22
|
+
{
|
|
23
|
+
provider: "playtron",
|
|
24
|
+
name: "Sign in with Playtron",
|
|
25
|
+
icon: ""
|
|
26
|
+
}
|
|
27
|
+
];
|
|
28
|
+
export {
|
|
29
|
+
ENOKI_PROVIDER_WALLETS_INFO
|
|
30
|
+
};
|
|
31
|
+
//# sourceMappingURL=providers.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/wallet/providers.ts"],
|
|
4
|
+
"sourcesContent": ["// Copyright (c) Mysten Labs, Inc.\n// SPDX-License-Identifier: Apache-2.0\n\nimport type { Wallet } from '@haneullabs/wallet-standard';\n\nimport type { AuthProvider } from '../EnokiClient/type.js';\n\nexport const ENOKI_PROVIDER_WALLETS_INFO: {\n\tname: string;\n\ticon: Wallet['icon'];\n\tprovider: AuthProvider;\n}[] = [\n\t{\n\t\tprovider: 'google',\n\t\tname: 'Sign in with Google',\n\t\ticon: '',\n\t},\n\t{\n\t\tprovider: 'facebook',\n\t\tname: 'Sign in with Facebook',\n\t\ticon: '',\n\t},\n\t{\n\t\tprovider: 'twitch',\n\t\tname: 'Sign in with Twitch',\n\t\ticon: '',\n\t},\n\t{\n\t\tprovider: 'onefc',\n\t\tname: 'Sign in with ONE Championship',\n\t\ticon: '',\n\t},\n\t{\n\t\tprovider: 'playtron',\n\t\tname: 'Sign in with Playtron',\n\t\ticon: '',\n\t},\n];\n"],
|
|
5
|
+
"mappings": "AAOO,MAAM,8BAIP;AAAA,EACL;AAAA,IACC,UAAU;AAAA,IACV,MAAM;AAAA,IACN,MAAM;AAAA,EACP;AAAA,EACA;AAAA,IACC,UAAU;AAAA,IACV,MAAM;AAAA,IACN,MAAM;AAAA,EACP;AAAA,EACA;AAAA,IACC,UAAU;AAAA,IACV,MAAM;AAAA,IACN,MAAM;AAAA,EACP;AAAA,EACA;AAAA,IACC,UAAU;AAAA,IACV,MAAM;AAAA,IACN,MAAM;AAAA,EACP;AAAA,EACA;AAAA,IACC,UAAU;AAAA,IACV,MAAM;AAAA,IACN,MAAM;AAAA,EACP;AACD;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { EnokiWallet } from './wallet.js';
|
|
2
|
+
import type { RegisterEnokiWalletsOptions } from './types.js';
|
|
3
|
+
import type { AuthProvider } from '../EnokiClient/type.js';
|
|
4
|
+
export declare function registerEnokiWallets({ providers, windowFeatures, ...config }: RegisterEnokiWalletsOptions): {
|
|
5
|
+
wallets: Partial<Record<AuthProvider, EnokiWallet>>;
|
|
6
|
+
unregister: () => void;
|
|
7
|
+
};
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { EnokiWallet } from "./wallet.js";
|
|
2
|
+
import { getWallets } from "@haneullabs/wallet-standard";
|
|
3
|
+
import { isEnokiNetwork } from "../utils.js";
|
|
4
|
+
import { ENOKI_PROVIDER_WALLETS_INFO } from "./providers.js";
|
|
5
|
+
function registerEnokiWallets({
|
|
6
|
+
providers,
|
|
7
|
+
windowFeatures = defaultWindowFeatures,
|
|
8
|
+
...config
|
|
9
|
+
}) {
|
|
10
|
+
const clients = "clients" in config ? config.clients : [Object.assign(config.client, { network: config.network ?? "mainnet" })];
|
|
11
|
+
const enokiCompatibleClients = clients.filter(({ network }) => isEnokiNetwork(network));
|
|
12
|
+
if (enokiCompatibleClients.length === 0) {
|
|
13
|
+
throw new Error("None of the specified clients are compatible with Enoki.");
|
|
14
|
+
}
|
|
15
|
+
const getCurrentNetwork = "clients" in config ? config.getCurrentNetwork : () => clients[0].network;
|
|
16
|
+
const walletsApi = getWallets();
|
|
17
|
+
const wallets = {};
|
|
18
|
+
for (const { name, icon, provider } of ENOKI_PROVIDER_WALLETS_INFO) {
|
|
19
|
+
const providerOptions = providers[provider];
|
|
20
|
+
if (providerOptions) {
|
|
21
|
+
wallets[provider] = new EnokiWallet({
|
|
22
|
+
...providerOptions,
|
|
23
|
+
name,
|
|
24
|
+
icon,
|
|
25
|
+
provider,
|
|
26
|
+
windowFeatures,
|
|
27
|
+
getCurrentNetwork,
|
|
28
|
+
apiKey: config.apiKey,
|
|
29
|
+
apiUrl: config.apiUrl,
|
|
30
|
+
additionalEpochs: config.additionalEpochs,
|
|
31
|
+
clients: enokiCompatibleClients
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
const unregister = walletsApi.register(...Object.values(wallets));
|
|
36
|
+
return { wallets, unregister };
|
|
37
|
+
}
|
|
38
|
+
function defaultWindowFeatures() {
|
|
39
|
+
const width = 500;
|
|
40
|
+
const height = 800;
|
|
41
|
+
const left = (screen.width - width) / 2;
|
|
42
|
+
const top = (screen.height - height) / 4;
|
|
43
|
+
return `popup=1;toolbar=0;status=0;resizable=1,width=${width},height=${height},top=${top},left=${left}`;
|
|
44
|
+
}
|
|
45
|
+
export {
|
|
46
|
+
registerEnokiWallets
|
|
47
|
+
};
|
|
48
|
+
//# sourceMappingURL=register.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/wallet/register.ts"],
|
|
4
|
+
"sourcesContent": ["// Copyright (c) Mysten Labs, Inc.\n// SPDX-License-Identifier: Apache-2.0\n\nimport { EnokiWallet } from './wallet.js';\nimport type { RegisterEnokiWalletsOptions } from './types.js';\nimport { getWallets } from '@haneullabs/wallet-standard';\nimport type { ClientWithCoreApi } from '@haneullabs/haneul/experimental';\nimport type { AuthProvider } from '../EnokiClient/type.js';\nimport { isEnokiNetwork } from '../utils.js';\nimport { ENOKI_PROVIDER_WALLETS_INFO } from './providers.js';\n\nexport function registerEnokiWallets({\n\tproviders,\n\twindowFeatures = defaultWindowFeatures,\n\t...config\n}: RegisterEnokiWalletsOptions) {\n\tconst clients: ClientWithCoreApi[] =\n\t\t'clients' in config\n\t\t\t? config.clients\n\t\t\t: [Object.assign(config.client, { network: config.network ?? 'mainnet' })];\n\n\tconst enokiCompatibleClients = clients.filter(({ network }) => isEnokiNetwork(network));\n\tif (enokiCompatibleClients.length === 0) {\n\t\tthrow new Error('None of the specified clients are compatible with Enoki.');\n\t}\n\n\tconst getCurrentNetwork =\n\t\t'clients' in config ? config.getCurrentNetwork : () => clients[0].network;\n\n\tconst walletsApi = getWallets();\n\tconst wallets: Partial<Record<AuthProvider, EnokiWallet>> = {};\n\n\tfor (const { name, icon, provider } of ENOKI_PROVIDER_WALLETS_INFO) {\n\t\tconst providerOptions = providers[provider];\n\t\tif (providerOptions) {\n\t\t\twallets[provider] = new EnokiWallet({\n\t\t\t\t...providerOptions,\n\t\t\t\tname,\n\t\t\t\ticon,\n\t\t\t\tprovider,\n\t\t\t\twindowFeatures,\n\t\t\t\tgetCurrentNetwork,\n\t\t\t\tapiKey: config.apiKey,\n\t\t\t\tapiUrl: config.apiUrl,\n\t\t\t\tadditionalEpochs: config.additionalEpochs,\n\t\t\t\tclients: enokiCompatibleClients,\n\t\t\t});\n\t\t}\n\t}\n\n\tconst unregister = walletsApi.register(...Object.values(wallets));\n\treturn { wallets, unregister };\n}\n\nfunction defaultWindowFeatures() {\n\tconst width = 500;\n\tconst height = 800;\n\tconst left = (screen.width - width) / 2;\n\tconst top = (screen.height - height) / 4;\n\n\treturn `popup=1;toolbar=0;status=0;resizable=1,width=${width},height=${height},top=${top},left=${left}`;\n}\n"],
|
|
5
|
+
"mappings": "AAGA,SAAS,mBAAmB;AAE5B,SAAS,kBAAkB;AAG3B,SAAS,sBAAsB;AAC/B,SAAS,mCAAmC;AAErC,SAAS,qBAAqB;AAAA,EACpC;AAAA,EACA,iBAAiB;AAAA,EACjB,GAAG;AACJ,GAAgC;AAC/B,QAAM,UACL,aAAa,SACV,OAAO,UACP,CAAC,OAAO,OAAO,OAAO,QAAQ,EAAE,SAAS,OAAO,WAAW,UAAU,CAAC,CAAC;AAE3E,QAAM,yBAAyB,QAAQ,OAAO,CAAC,EAAE,QAAQ,MAAM,eAAe,OAAO,CAAC;AACtF,MAAI,uBAAuB,WAAW,GAAG;AACxC,UAAM,IAAI,MAAM,0DAA0D;AAAA,EAC3E;AAEA,QAAM,oBACL,aAAa,SAAS,OAAO,oBAAoB,MAAM,QAAQ,CAAC,EAAE;AAEnE,QAAM,aAAa,WAAW;AAC9B,QAAM,UAAsD,CAAC;AAE7D,aAAW,EAAE,MAAM,MAAM,SAAS,KAAK,6BAA6B;AACnE,UAAM,kBAAkB,UAAU,QAAQ;AAC1C,QAAI,iBAAiB;AACpB,cAAQ,QAAQ,IAAI,IAAI,YAAY;AAAA,QACnC,GAAG;AAAA,QACH;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA,QAAQ,OAAO;AAAA,QACf,QAAQ,OAAO;AAAA,QACf,kBAAkB,OAAO;AAAA,QACzB,SAAS;AAAA,MACV,CAAC;AAAA,IACF;AAAA,EACD;AAEA,QAAM,aAAa,WAAW,SAAS,GAAG,OAAO,OAAO,OAAO,CAAC;AAChE,SAAO,EAAE,SAAS,WAAW;AAC9B;AAEA,SAAS,wBAAwB;AAChC,QAAM,QAAQ;AACd,QAAM,SAAS;AACf,QAAM,QAAQ,OAAO,QAAQ,SAAS;AACtC,QAAM,OAAO,OAAO,SAAS,UAAU;AAEvC,SAAO,gDAAgD,KAAK,WAAW,MAAM,QAAQ,GAAG,SAAS,IAAI;AACtG;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { WritableAtom } from 'nanostores';
|
|
2
|
+
import type { EnokiClientConfig } from '../EnokiClient/index.js';
|
|
3
|
+
import type { ClientWithCoreApi, Experimental_HaneulClientTypes } from '@haneullabs/haneul/experimental';
|
|
4
|
+
import type { EnokiSessionContext, ZkLoginSession, ZkLoginState } from './types.js';
|
|
5
|
+
export type EnokiWalletStateConfig = EnokiClientConfig & {
|
|
6
|
+
clients: ClientWithCoreApi[];
|
|
7
|
+
clientId: string;
|
|
8
|
+
};
|
|
9
|
+
export declare class EnokiWalletState {
|
|
10
|
+
#private;
|
|
11
|
+
constructor(config: EnokiWalletStateConfig);
|
|
12
|
+
get zkLoginState(): WritableAtom<ZkLoginState | null>;
|
|
13
|
+
get sessionContextByNetwork(): Map<Experimental_HaneulClientTypes.Network, EnokiSessionContext>;
|
|
14
|
+
getSessionContext(network: Experimental_HaneulClientTypes.Network): EnokiSessionContext;
|
|
15
|
+
logout(): Promise<void>;
|
|
16
|
+
setSession(context: EnokiSessionContext, newValue: ZkLoginSession | null): Promise<void>;
|
|
17
|
+
getSession({ $zkLoginSession, idbStore }: EnokiSessionContext): Promise<ZkLoginSession | null>;
|
|
18
|
+
}
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
var __typeError = (msg) => {
|
|
2
|
+
throw TypeError(msg);
|
|
3
|
+
};
|
|
4
|
+
var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
|
|
5
|
+
var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
|
|
6
|
+
var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
7
|
+
var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
|
|
8
|
+
var __privateMethod = (obj, member, method) => (__accessCheck(obj, member, "access private method"), method);
|
|
9
|
+
var _encryption, _encryptionKey, _stateStore, _sessionContextByNetwork, _zkLoginState, _EnokiWalletState_instances, createZkLoginState_fn;
|
|
10
|
+
import { clear, createStore, del, get, set } from "idb-keyval";
|
|
11
|
+
import { atom, onMount, onSet, task } from "nanostores";
|
|
12
|
+
import { createDefaultEncryption } from "../encryption.js";
|
|
13
|
+
const sessionKey = "zklogin-session";
|
|
14
|
+
const stateKey = "zklogin-state";
|
|
15
|
+
class EnokiWalletState {
|
|
16
|
+
constructor(config) {
|
|
17
|
+
__privateAdd(this, _EnokiWalletState_instances);
|
|
18
|
+
__privateAdd(this, _encryption);
|
|
19
|
+
__privateAdd(this, _encryptionKey);
|
|
20
|
+
__privateAdd(this, _stateStore);
|
|
21
|
+
__privateAdd(this, _sessionContextByNetwork);
|
|
22
|
+
__privateAdd(this, _zkLoginState);
|
|
23
|
+
__privateSet(this, _encryptionKey, config.apiKey);
|
|
24
|
+
__privateSet(this, _encryption, createDefaultEncryption());
|
|
25
|
+
__privateSet(this, _stateStore, createStore(`${config.apiKey}_${config.clientId}`, "enoki"));
|
|
26
|
+
__privateSet(this, _zkLoginState, __privateMethod(this, _EnokiWalletState_instances, createZkLoginState_fn).call(this));
|
|
27
|
+
__privateSet(this, _sessionContextByNetwork, config.clients.reduce((accumulator, client) => {
|
|
28
|
+
const network = client.network;
|
|
29
|
+
const idbStore = createStore(`${config.apiKey}_${network}_${config.clientId}`, "enoki");
|
|
30
|
+
const sessionContext = {
|
|
31
|
+
$zkLoginSession: atom({ initialized: false, value: null }),
|
|
32
|
+
client,
|
|
33
|
+
idbStore
|
|
34
|
+
};
|
|
35
|
+
onMount(sessionContext.$zkLoginSession, () => {
|
|
36
|
+
this.getSession(sessionContext);
|
|
37
|
+
});
|
|
38
|
+
return accumulator.set(network, sessionContext);
|
|
39
|
+
}, /* @__PURE__ */ new Map()));
|
|
40
|
+
}
|
|
41
|
+
get zkLoginState() {
|
|
42
|
+
return __privateGet(this, _zkLoginState);
|
|
43
|
+
}
|
|
44
|
+
get sessionContextByNetwork() {
|
|
45
|
+
return __privateGet(this, _sessionContextByNetwork);
|
|
46
|
+
}
|
|
47
|
+
getSessionContext(network) {
|
|
48
|
+
const context = __privateGet(this, _sessionContextByNetwork).get(network);
|
|
49
|
+
if (!context) {
|
|
50
|
+
throw new Error(`The network ${network} isn't supported.`);
|
|
51
|
+
}
|
|
52
|
+
return context;
|
|
53
|
+
}
|
|
54
|
+
async logout() {
|
|
55
|
+
__privateGet(this, _zkLoginState).set(null);
|
|
56
|
+
await clear(__privateGet(this, _stateStore));
|
|
57
|
+
for (const context of __privateGet(this, _sessionContextByNetwork).values()) {
|
|
58
|
+
await this.setSession(context, null);
|
|
59
|
+
await clear(context.idbStore);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
async setSession(context, newValue) {
|
|
63
|
+
if (newValue) {
|
|
64
|
+
const storedValue = await __privateGet(this, _encryption).encrypt(
|
|
65
|
+
__privateGet(this, _encryptionKey),
|
|
66
|
+
JSON.stringify(newValue)
|
|
67
|
+
);
|
|
68
|
+
await set(sessionKey, storedValue, context.idbStore);
|
|
69
|
+
} else {
|
|
70
|
+
await del(sessionKey, context.idbStore);
|
|
71
|
+
}
|
|
72
|
+
context.$zkLoginSession.set({ initialized: true, value: newValue });
|
|
73
|
+
}
|
|
74
|
+
async getSession({ $zkLoginSession, idbStore }) {
|
|
75
|
+
if ($zkLoginSession.get().initialized) {
|
|
76
|
+
return $zkLoginSession.get().value;
|
|
77
|
+
}
|
|
78
|
+
try {
|
|
79
|
+
const storedValue = await get(sessionKey, idbStore);
|
|
80
|
+
if (!storedValue) return null;
|
|
81
|
+
const state = JSON.parse(
|
|
82
|
+
await __privateGet(this, _encryption).decrypt(__privateGet(this, _encryptionKey), storedValue)
|
|
83
|
+
);
|
|
84
|
+
if (state?.expiresAt && Date.now() > state.expiresAt) {
|
|
85
|
+
await this.logout();
|
|
86
|
+
} else {
|
|
87
|
+
$zkLoginSession.set({ initialized: true, value: state });
|
|
88
|
+
}
|
|
89
|
+
} catch {
|
|
90
|
+
$zkLoginSession.set({ initialized: true, value: null });
|
|
91
|
+
}
|
|
92
|
+
return $zkLoginSession.get().value;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
_encryption = new WeakMap();
|
|
96
|
+
_encryptionKey = new WeakMap();
|
|
97
|
+
_stateStore = new WeakMap();
|
|
98
|
+
_sessionContextByNetwork = new WeakMap();
|
|
99
|
+
_zkLoginState = new WeakMap();
|
|
100
|
+
_EnokiWalletState_instances = new WeakSet();
|
|
101
|
+
createZkLoginState_fn = function() {
|
|
102
|
+
const $zkLoginState = atom(null);
|
|
103
|
+
onMount($zkLoginState, () => {
|
|
104
|
+
task(async () => {
|
|
105
|
+
try {
|
|
106
|
+
const rawStoredValue = await get(stateKey, __privateGet(this, _stateStore));
|
|
107
|
+
if (rawStoredValue) {
|
|
108
|
+
$zkLoginState.set(JSON.parse(rawStoredValue));
|
|
109
|
+
}
|
|
110
|
+
} catch {
|
|
111
|
+
}
|
|
112
|
+
});
|
|
113
|
+
});
|
|
114
|
+
onSet($zkLoginState, ({ newValue }) => {
|
|
115
|
+
set(stateKey, JSON.stringify(newValue), __privateGet(this, _stateStore));
|
|
116
|
+
});
|
|
117
|
+
return $zkLoginState;
|
|
118
|
+
};
|
|
119
|
+
export {
|
|
120
|
+
EnokiWalletState
|
|
121
|
+
};
|
|
122
|
+
//# sourceMappingURL=state.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/wallet/state.ts"],
|
|
4
|
+
"sourcesContent": ["// Copyright (c) Mysten Labs, Inc.\n// SPDX-License-Identifier: Apache-2.0\n\nimport type { UseStore } from 'idb-keyval';\nimport { clear, createStore, del, get, set } from 'idb-keyval';\nimport type { WritableAtom } from 'nanostores';\nimport { atom, onMount, onSet, task } from 'nanostores';\n\nimport type { Encryption } from '../encryption.js';\nimport { createDefaultEncryption } from '../encryption.js';\nimport type { EnokiClientConfig } from '../EnokiClient/index.js';\nimport type { ClientWithCoreApi, Experimental_HaneulClientTypes } from '@haneullabs/haneul/experimental';\n\nimport type { EnokiSessionContext, ZkLoginSession, ZkLoginState } from './types.js';\n\nexport type EnokiWalletStateConfig = EnokiClientConfig & {\n\tclients: ClientWithCoreApi[];\n\tclientId: string;\n};\n\nconst sessionKey = 'zklogin-session';\n\nconst stateKey = 'zklogin-state';\n\nexport class EnokiWalletState {\n\t#encryption: Encryption;\n\t#encryptionKey: string;\n\n\t#stateStore: UseStore;\n\t#sessionContextByNetwork: Map<Experimental_HaneulClientTypes.Network, EnokiSessionContext>;\n\t#zkLoginState: WritableAtom<ZkLoginState | null>;\n\n\tconstructor(config: EnokiWalletStateConfig) {\n\t\tthis.#encryptionKey = config.apiKey;\n\t\tthis.#encryption = createDefaultEncryption();\n\n\t\tthis.#stateStore = createStore(`${config.apiKey}_${config.clientId}`, 'enoki');\n\t\tthis.#zkLoginState = this.#createZkLoginState();\n\n\t\tthis.#sessionContextByNetwork = config.clients.reduce((accumulator, client) => {\n\t\t\tconst network = client.network;\n\t\t\tconst idbStore = createStore(`${config.apiKey}_${network}_${config.clientId}`, 'enoki');\n\n\t\t\tconst sessionContext: EnokiSessionContext = {\n\t\t\t\t$zkLoginSession: atom({ initialized: false, value: null }),\n\t\t\t\tclient,\n\t\t\t\tidbStore,\n\t\t\t};\n\n\t\t\tonMount(sessionContext.$zkLoginSession, () => {\n\t\t\t\tthis.getSession(sessionContext);\n\t\t\t});\n\n\t\t\treturn accumulator.set(network, sessionContext);\n\t\t}, new Map());\n\t}\n\n\tget zkLoginState() {\n\t\treturn this.#zkLoginState;\n\t}\n\n\tget sessionContextByNetwork() {\n\t\treturn this.#sessionContextByNetwork;\n\t}\n\n\tgetSessionContext(network: Experimental_HaneulClientTypes.Network) {\n\t\tconst context = this.#sessionContextByNetwork.get(network);\n\t\tif (!context) {\n\t\t\tthrow new Error(`The network ${network} isn't supported.`);\n\t\t}\n\n\t\treturn context;\n\t}\n\n\tasync logout() {\n\t\tthis.#zkLoginState.set(null);\n\t\tawait clear(this.#stateStore);\n\n\t\tfor (const context of this.#sessionContextByNetwork.values()) {\n\t\t\tawait this.setSession(context, null);\n\t\t\tawait clear(context.idbStore);\n\t\t}\n\t}\n\n\tasync setSession(context: EnokiSessionContext, newValue: ZkLoginSession | null) {\n\t\tif (newValue) {\n\t\t\tconst storedValue = await this.#encryption.encrypt(\n\t\t\t\tthis.#encryptionKey,\n\t\t\t\tJSON.stringify(newValue),\n\t\t\t);\n\n\t\t\tawait set(sessionKey, storedValue, context.idbStore);\n\t\t} else {\n\t\t\tawait del(sessionKey, context.idbStore);\n\t\t}\n\n\t\tcontext.$zkLoginSession.set({ initialized: true, value: newValue });\n\t}\n\n\tasync getSession({ $zkLoginSession, idbStore }: EnokiSessionContext) {\n\t\tif ($zkLoginSession.get().initialized) {\n\t\t\treturn $zkLoginSession.get().value;\n\t\t}\n\n\t\ttry {\n\t\t\tconst storedValue = await get(sessionKey, idbStore);\n\t\t\tif (!storedValue) return null;\n\n\t\t\tconst state: ZkLoginSession = JSON.parse(\n\t\t\t\tawait this.#encryption.decrypt(this.#encryptionKey, storedValue),\n\t\t\t);\n\n\t\t\tif (state?.expiresAt && Date.now() > state.expiresAt) {\n\t\t\t\tawait this.logout();\n\t\t\t} else {\n\t\t\t\t$zkLoginSession.set({ initialized: true, value: state });\n\t\t\t}\n\t\t} catch {\n\t\t\t$zkLoginSession.set({ initialized: true, value: null });\n\t\t}\n\n\t\treturn $zkLoginSession.get().value;\n\t}\n\n\t#createZkLoginState() {\n\t\tconst $zkLoginState = atom<ZkLoginState | null>(null);\n\n\t\tonMount($zkLoginState, () => {\n\t\t\ttask(async () => {\n\t\t\t\ttry {\n\t\t\t\t\tconst rawStoredValue = await get<string>(stateKey, this.#stateStore);\n\t\t\t\t\tif (rawStoredValue) {\n\t\t\t\t\t\t$zkLoginState.set(JSON.parse(rawStoredValue));\n\t\t\t\t\t}\n\t\t\t\t} catch {\n\t\t\t\t\t// Ignore errors\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\n\t\tonSet($zkLoginState, ({ newValue }) => {\n\t\t\tset(stateKey, JSON.stringify(newValue), this.#stateStore);\n\t\t});\n\n\t\treturn $zkLoginState;\n\t}\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import type { HaneulClient } from '@haneullabs/haneul/client';
|
|
2
|
+
import type { StandardEventsListeners, Wallet } from '@haneullabs/wallet-standard';
|
|
3
|
+
import type { EnokiClientConfig } from '../EnokiClient/index.js';
|
|
4
|
+
import type { AuthProvider, EnokiNetwork } from '../EnokiClient/type.js';
|
|
5
|
+
import type { ClientWithCoreApi, Experimental_HaneulClientTypes } from '@haneullabs/haneul/experimental';
|
|
6
|
+
import type { ZkLoginSignatureInputs } from '@haneullabs/haneul/zklogin';
|
|
7
|
+
import type { UseStore } from 'idb-keyval';
|
|
8
|
+
import type { WritableAtom } from 'nanostores';
|
|
9
|
+
export type WalletEventsMap = {
|
|
10
|
+
[E in keyof StandardEventsListeners]: Parameters<StandardEventsListeners[E]>[0];
|
|
11
|
+
};
|
|
12
|
+
export type ZkLoginState = {
|
|
13
|
+
address: string;
|
|
14
|
+
publicKey: string;
|
|
15
|
+
};
|
|
16
|
+
export type ZkLoginSession = {
|
|
17
|
+
maxEpoch: number;
|
|
18
|
+
randomness: string;
|
|
19
|
+
expiresAt: number;
|
|
20
|
+
jwt?: string;
|
|
21
|
+
proof?: ZkLoginSignatureInputs;
|
|
22
|
+
};
|
|
23
|
+
export type EnokiSessionContext = {
|
|
24
|
+
idbStore: UseStore;
|
|
25
|
+
client: ClientWithCoreApi;
|
|
26
|
+
$zkLoginSession: WritableAtom<{
|
|
27
|
+
initialized: boolean;
|
|
28
|
+
value: ZkLoginSession | null;
|
|
29
|
+
}>;
|
|
30
|
+
};
|
|
31
|
+
type ClientConfig = {
|
|
32
|
+
/**
|
|
33
|
+
* A list of client instances to use when building and executing transactions.
|
|
34
|
+
*/
|
|
35
|
+
clients: ClientWithCoreApi[];
|
|
36
|
+
/**
|
|
37
|
+
* A function that returns the current network that the application is acting on.
|
|
38
|
+
*/
|
|
39
|
+
getCurrentNetwork: () => Experimental_HaneulClientTypes.Network;
|
|
40
|
+
};
|
|
41
|
+
export type EnokiWalletOptions = {
|
|
42
|
+
/**
|
|
43
|
+
* The window features to use when opening the authorization popup.
|
|
44
|
+
* https://developer.mozilla.org/en-US/docs/Web/API/Window/open#windowfeatures
|
|
45
|
+
*/
|
|
46
|
+
windowFeatures?: string | (() => string);
|
|
47
|
+
/**
|
|
48
|
+
* The authentication provider to register the wallet for.
|
|
49
|
+
*/
|
|
50
|
+
provider: AuthProvider;
|
|
51
|
+
} & AuthProviderOptions & EnokiClientConfig & ClientConfig & Pick<Wallet, 'name' | 'icon'>;
|
|
52
|
+
export type AuthProviderOptions = {
|
|
53
|
+
/**
|
|
54
|
+
* The OAuth client ID.
|
|
55
|
+
*/
|
|
56
|
+
clientId: string;
|
|
57
|
+
/**
|
|
58
|
+
* The URL to redirect to after authorization.
|
|
59
|
+
*/
|
|
60
|
+
redirectUrl?: string;
|
|
61
|
+
/**
|
|
62
|
+
* Extra parameters to include in the authorization URL.
|
|
63
|
+
*/
|
|
64
|
+
extraParams?: Record<string, string> | (() => Record<string, string>);
|
|
65
|
+
};
|
|
66
|
+
export type RegisterEnokiWalletsOptions = {
|
|
67
|
+
/**
|
|
68
|
+
* Configuration for each OAuth provider.
|
|
69
|
+
*/
|
|
70
|
+
providers: Partial<Record<AuthProvider, AuthProviderOptions>>;
|
|
71
|
+
} & Pick<EnokiWalletOptions, 'apiKey' | 'apiUrl' | 'additionalEpochs' | 'windowFeatures'> & (ClientConfig | {
|
|
72
|
+
/**
|
|
73
|
+
* The HaneulClient instance to use when building and executing transactions.
|
|
74
|
+
*/
|
|
75
|
+
client: HaneulClient;
|
|
76
|
+
/**
|
|
77
|
+
* The network to use when building and executing transactions.
|
|
78
|
+
* @default 'mainnet'
|
|
79
|
+
*/
|
|
80
|
+
network?: EnokiNetwork;
|
|
81
|
+
});
|
|
82
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Wallet } from '@haneullabs/wallet-standard';
|
|
2
|
+
import type { UiWallet } from '@wallet-standard/ui';
|
|
3
|
+
import type { EnokiWallet } from './wallet.js';
|
|
4
|
+
import type { EnokiGetSessionInput } from './features.js';
|
|
5
|
+
export declare function isEnokiWallet(wallet: UiWallet): boolean;
|
|
6
|
+
export declare function isEnokiWallet(wallet: Wallet): wallet is EnokiWallet;
|
|
7
|
+
export declare function getWalletMetadata(wallet: Wallet | UiWallet): import("./features.js").EnokiGetMetadataOutput | null;
|
|
8
|
+
export declare function getSession(wallet: Wallet | UiWallet, input?: EnokiGetSessionInput): Promise<import("./features.js").EnokiGetSessionOutput>;
|
|
9
|
+
export declare function isGoogleWallet(wallet: Wallet | UiWallet): boolean;
|
|
10
|
+
export declare function isTwitchWallet(wallet: Wallet | UiWallet): boolean;
|
|
11
|
+
export declare function isFacebookWallet(wallet: Wallet | UiWallet): boolean;
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { getWalletFeature } from "@wallet-standard/ui";
|
|
2
|
+
import { EnokiGetMetadata, EnokiGetSession } from "./features.js";
|
|
3
|
+
function isEnokiWallet(wallet) {
|
|
4
|
+
if (isWalletHandle(wallet)) {
|
|
5
|
+
return wallet.features.includes(EnokiGetMetadata);
|
|
6
|
+
}
|
|
7
|
+
return EnokiGetMetadata in wallet.features;
|
|
8
|
+
}
|
|
9
|
+
function getWalletMetadata(wallet) {
|
|
10
|
+
if (isWalletHandle(wallet)) {
|
|
11
|
+
try {
|
|
12
|
+
const { getMetadata } = getWalletFeature(
|
|
13
|
+
wallet,
|
|
14
|
+
EnokiGetMetadata
|
|
15
|
+
);
|
|
16
|
+
return getMetadata();
|
|
17
|
+
} catch {
|
|
18
|
+
return null;
|
|
19
|
+
}
|
|
20
|
+
} else if (EnokiGetMetadata in wallet.features) {
|
|
21
|
+
const walletWithFeature = wallet;
|
|
22
|
+
return walletWithFeature.features[EnokiGetMetadata].getMetadata();
|
|
23
|
+
}
|
|
24
|
+
return null;
|
|
25
|
+
}
|
|
26
|
+
async function getSession(wallet, input) {
|
|
27
|
+
if (isWalletHandle(wallet)) {
|
|
28
|
+
try {
|
|
29
|
+
const { getSession: getSession2 } = getWalletFeature(
|
|
30
|
+
wallet,
|
|
31
|
+
EnokiGetSession
|
|
32
|
+
);
|
|
33
|
+
return await getSession2(input);
|
|
34
|
+
} catch {
|
|
35
|
+
return null;
|
|
36
|
+
}
|
|
37
|
+
} else if (EnokiGetSession in wallet.features) {
|
|
38
|
+
const walletWithFeature = wallet;
|
|
39
|
+
return await walletWithFeature.features[EnokiGetSession].getSession(input);
|
|
40
|
+
}
|
|
41
|
+
return null;
|
|
42
|
+
}
|
|
43
|
+
function isGoogleWallet(wallet) {
|
|
44
|
+
return getWalletMetadata(wallet)?.provider === "google";
|
|
45
|
+
}
|
|
46
|
+
function isTwitchWallet(wallet) {
|
|
47
|
+
return getWalletMetadata(wallet)?.provider === "twitch";
|
|
48
|
+
}
|
|
49
|
+
function isFacebookWallet(wallet) {
|
|
50
|
+
return getWalletMetadata(wallet)?.provider === "facebook";
|
|
51
|
+
}
|
|
52
|
+
function isWalletHandle(wallet) {
|
|
53
|
+
return Array.isArray(wallet.features);
|
|
54
|
+
}
|
|
55
|
+
export {
|
|
56
|
+
getSession,
|
|
57
|
+
getWalletMetadata,
|
|
58
|
+
isEnokiWallet,
|
|
59
|
+
isFacebookWallet,
|
|
60
|
+
isGoogleWallet,
|
|
61
|
+
isTwitchWallet
|
|
62
|
+
};
|
|
63
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/wallet/utils.ts"],
|
|
4
|
+
"sourcesContent": ["// Copyright (c) Mysten Labs, Inc.\n// SPDX-License-Identifier: Apache-2.0\n\nimport type { Wallet, WalletWithFeatures } from '@haneullabs/wallet-standard';\nimport type { UiWallet } from '@wallet-standard/ui';\nimport { getWalletFeature } from '@wallet-standard/ui';\nimport type { EnokiWallet } from './wallet.js';\nimport type {\n\tEnokiGetMetadataFeature,\n\tEnokiGetSessionFeature,\n\tEnokiGetSessionInput,\n} from './features.js';\nimport { EnokiGetMetadata, EnokiGetSession } from './features.js';\n\nexport function isEnokiWallet(wallet: UiWallet): boolean;\nexport function isEnokiWallet(wallet: Wallet): wallet is EnokiWallet;\nexport function isEnokiWallet(wallet: Wallet | UiWallet) {\n\tif (isWalletHandle(wallet)) {\n\t\treturn wallet.features.includes(EnokiGetMetadata);\n\t}\n\treturn EnokiGetMetadata in wallet.features;\n}\n\nexport function getWalletMetadata(wallet: Wallet | UiWallet) {\n\tif (isWalletHandle(wallet)) {\n\t\ttry {\n\t\t\tconst { getMetadata } = getWalletFeature(\n\t\t\t\twallet,\n\t\t\t\tEnokiGetMetadata,\n\t\t\t) as EnokiGetMetadataFeature[typeof EnokiGetMetadata];\n\n\t\t\treturn getMetadata();\n\t\t} catch {\n\t\t\treturn null;\n\t\t}\n\t} else if (EnokiGetMetadata in wallet.features) {\n\t\tconst walletWithFeature = wallet as WalletWithFeatures<EnokiGetMetadataFeature>;\n\t\treturn walletWithFeature.features[EnokiGetMetadata].getMetadata();\n\t}\n\treturn null;\n}\n\nexport async function getSession(wallet: Wallet | UiWallet, input?: EnokiGetSessionInput) {\n\tif (isWalletHandle(wallet)) {\n\t\ttry {\n\t\t\tconst { getSession } = getWalletFeature(\n\t\t\t\twallet,\n\t\t\t\tEnokiGetSession,\n\t\t\t) as EnokiGetSessionFeature[typeof EnokiGetSession];\n\n\t\t\treturn await getSession(input);\n\t\t} catch {\n\t\t\treturn null;\n\t\t}\n\t} else if (EnokiGetSession in wallet.features) {\n\t\tconst walletWithFeature = wallet as WalletWithFeatures<EnokiGetSessionFeature>;\n\t\treturn await walletWithFeature.features[EnokiGetSession].getSession(input);\n\t}\n\treturn null;\n}\n\nexport function isGoogleWallet(wallet: Wallet | UiWallet) {\n\treturn getWalletMetadata(wallet)?.provider === 'google';\n}\n\nexport function isTwitchWallet(wallet: Wallet | UiWallet) {\n\treturn getWalletMetadata(wallet)?.provider === 'twitch';\n}\n\nexport function isFacebookWallet(wallet: Wallet | UiWallet) {\n\treturn getWalletMetadata(wallet)?.provider === 'facebook';\n}\n\nfunction isWalletHandle(wallet: UiWallet | Wallet): wallet is UiWallet {\n\t// TypeScript doesn't properly narrow readonly arrays:\n\t// https://github.com/microsoft/TypeScript/issues/1700\n\treturn Array.isArray(wallet.features);\n}\n"],
|
|
5
|
+
"mappings": "AAKA,SAAS,wBAAwB;AAOjC,SAAS,kBAAkB,uBAAuB;AAI3C,SAAS,cAAc,QAA2B;AACxD,MAAI,eAAe,MAAM,GAAG;AAC3B,WAAO,OAAO,SAAS,SAAS,gBAAgB;AAAA,EACjD;AACA,SAAO,oBAAoB,OAAO;AACnC;AAEO,SAAS,kBAAkB,QAA2B;AAC5D,MAAI,eAAe,MAAM,GAAG;AAC3B,QAAI;AACH,YAAM,EAAE,YAAY,IAAI;AAAA,QACvB;AAAA,QACA;AAAA,MACD;AAEA,aAAO,YAAY;AAAA,IACpB,QAAQ;AACP,aAAO;AAAA,IACR;AAAA,EACD,WAAW,oBAAoB,OAAO,UAAU;AAC/C,UAAM,oBAAoB;AAC1B,WAAO,kBAAkB,SAAS,gBAAgB,EAAE,YAAY;AAAA,EACjE;AACA,SAAO;AACR;AAEA,eAAsB,WAAW,QAA2B,OAA8B;AACzF,MAAI,eAAe,MAAM,GAAG;AAC3B,QAAI;AACH,YAAM,EAAE,YAAAA,YAAW,IAAI;AAAA,QACtB;AAAA,QACA;AAAA,MACD;AAEA,aAAO,MAAMA,YAAW,KAAK;AAAA,IAC9B,QAAQ;AACP,aAAO;AAAA,IACR;AAAA,EACD,WAAW,mBAAmB,OAAO,UAAU;AAC9C,UAAM,oBAAoB;AAC1B,WAAO,MAAM,kBAAkB,SAAS,eAAe,EAAE,WAAW,KAAK;AAAA,EAC1E;AACA,SAAO;AACR;AAEO,SAAS,eAAe,QAA2B;AACzD,SAAO,kBAAkB,MAAM,GAAG,aAAa;AAChD;AAEO,SAAS,eAAe,QAA2B;AACzD,SAAO,kBAAkB,MAAM,GAAG,aAAa;AAChD;AAEO,SAAS,iBAAiB,QAA2B;AAC3D,SAAO,kBAAkB,MAAM,GAAG,aAAa;AAChD;AAEA,SAAS,eAAe,QAA+C;AAGtE,SAAO,MAAM,QAAQ,OAAO,QAAQ;AACrC;",
|
|
6
|
+
"names": ["getSession"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { StandardConnectFeature, StandardDisconnectFeature, StandardEventsFeature, HaneulSignAndExecuteTransactionFeature, HaneulSignPersonalMessageFeature, HaneulSignTransactionFeature, Wallet } from '@haneullabs/wallet-standard';
|
|
2
|
+
import { ReadonlyWalletAccount } from '@haneullabs/wallet-standard';
|
|
3
|
+
import type { AuthProvider } from '../EnokiClient/type.js';
|
|
4
|
+
import type { EnokiWalletOptions } from './types.js';
|
|
5
|
+
import type { EnokiGetMetadataFeature, EnokiGetSessionFeature } from './features.js';
|
|
6
|
+
export declare class EnokiWallet implements Wallet {
|
|
7
|
+
#private;
|
|
8
|
+
get name(): string;
|
|
9
|
+
get provider(): AuthProvider;
|
|
10
|
+
get icon(): `data:image/svg+xml;base64,${string}` | `data:image/webp;base64,${string}` | `data:image/png;base64,${string}` | `data:image/gif;base64,${string}`;
|
|
11
|
+
get version(): "1.0.0";
|
|
12
|
+
get chains(): `sui:${string & {}}`[];
|
|
13
|
+
get accounts(): ReadonlyWalletAccount[];
|
|
14
|
+
get features(): StandardConnectFeature & StandardDisconnectFeature & StandardEventsFeature & HaneulSignTransactionFeature & HaneulSignAndExecuteTransactionFeature & HaneulSignPersonalMessageFeature & EnokiGetMetadataFeature & EnokiGetSessionFeature;
|
|
15
|
+
constructor({ name, icon, provider, clientId, redirectUrl, extraParams, windowFeatures, getCurrentNetwork, apiKey, apiUrl, additionalEpochs, clients, }: EnokiWalletOptions);
|
|
16
|
+
}
|