@tonconnect/sdk 0.0.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/LICENSE +201 -0
- package/README.md +83 -0
- package/lib/errors/generate-error.d.ts +2 -0
- package/lib/errors/generate-error.js +19 -0
- package/lib/errors/generate-error.js.map +1 -0
- package/lib/errors/index.d.ts +1 -0
- package/lib/errors/index.js +5 -0
- package/lib/errors/index.js.map +1 -0
- package/lib/errors/protocol/events/connect/index.d.ts +1 -0
- package/lib/errors/protocol/events/connect/index.js +6 -0
- package/lib/errors/protocol/events/connect/index.js.map +1 -0
- package/lib/errors/protocol/events/connect/user-rejects.error.d.ts +1 -0
- package/lib/errors/protocol/events/connect/user-rejects.error.js +6 -0
- package/lib/errors/protocol/events/connect/user-rejects.error.js.map +1 -0
- package/lib/errors/protocol/events/index.d.ts +1 -0
- package/lib/errors/protocol/events/index.js +5 -0
- package/lib/errors/protocol/events/index.js.map +1 -0
- package/lib/errors/protocol/index.d.ts +1 -0
- package/lib/errors/protocol/index.js +5 -0
- package/lib/errors/protocol/index.js.map +1 -0
- package/lib/errors/storage/localstorage-not-found.error.d.ts +1 -0
- package/lib/errors/storage/localstorage-not-found.error.js +6 -0
- package/lib/errors/storage/localstorage-not-found.error.js.map +1 -0
- package/lib/errors/ton-connect.error.d.ts +3 -0
- package/lib/errors/ton-connect.error.js +15 -0
- package/lib/errors/ton-connect.error.js.map +1 -0
- package/lib/errors/unknown.error.d.ts +1 -0
- package/lib/errors/unknown.error.js +6 -0
- package/lib/errors/unknown.error.js.map +1 -0
- package/lib/errors/wallet/wallet-already-connected.error.d.ts +1 -0
- package/lib/errors/wallet/wallet-already-connected.error.js +6 -0
- package/lib/errors/wallet/wallet-already-connected.error.js.map +1 -0
- package/lib/errors/wallet/wallet-not-connected.error.d.ts +1 -0
- package/lib/errors/wallet/wallet-not-connected.error.js +6 -0
- package/lib/errors/wallet/wallet-not-connected.error.js.map +1 -0
- package/lib/errors/wallet/wallet-not-injected.error.d.ts +1 -0
- package/lib/errors/wallet/wallet-not-injected.error.js +6 -0
- package/lib/errors/wallet/wallet-not-injected.error.js.map +1 -0
- package/lib/index.d.ts +2 -0
- package/lib/index.js +8 -0
- package/lib/index.js.map +1 -0
- package/lib/models/dapp/dapp-metadata.d.ts +5 -0
- package/lib/models/dapp/dapp-metadata.js +3 -0
- package/lib/models/dapp/dapp-metadata.js.map +1 -0
- package/lib/models/dapp/dapp-settings.d.ts +6 -0
- package/lib/models/dapp/dapp-settings.js +3 -0
- package/lib/models/dapp/dapp-settings.js.map +1 -0
- package/lib/models/index.d.ts +3 -0
- package/lib/models/index.js +5 -0
- package/lib/models/index.js.map +1 -0
- package/lib/models/methods/index.d.ts +1 -0
- package/lib/models/methods/index.js +5 -0
- package/lib/models/methods/index.js.map +1 -0
- package/lib/models/methods/send-transaction/index.d.ts +2 -0
- package/lib/models/methods/send-transaction/index.js +3 -0
- package/lib/models/methods/send-transaction/index.js.map +1 -0
- package/lib/models/methods/send-transaction/send-transaction-request.d.ts +9 -0
- package/lib/models/methods/send-transaction/send-transaction-request.js +3 -0
- package/lib/models/methods/send-transaction/send-transaction-request.js.map +1 -0
- package/lib/models/methods/send-transaction/send-transaction-response.d.ts +3 -0
- package/lib/models/methods/send-transaction/send-transaction-response.js +3 -0
- package/lib/models/methods/send-transaction/send-transaction-response.js.map +1 -0
- package/lib/models/wallet/account.d.ts +5 -0
- package/lib/models/wallet/account.js +3 -0
- package/lib/models/wallet/account.js.map +1 -0
- package/lib/models/wallet/index.d.ts +3 -0
- package/lib/models/wallet/index.js +3 -0
- package/lib/models/wallet/index.js.map +1 -0
- package/lib/models/wallet/wallet-connection-source.d.ts +4 -0
- package/lib/models/wallet/wallet-connection-source.js +3 -0
- package/lib/models/wallet/wallet-connection-source.js.map +1 -0
- package/lib/models/wallet/wallet.d.ts +7 -0
- package/lib/models/wallet/wallet.js +3 -0
- package/lib/models/wallet/wallet.js.map +1 -0
- package/lib/parsers/connect-errors-parser.d.ts +8 -0
- package/lib/parsers/connect-errors-parser.js +23 -0
- package/lib/parsers/connect-errors-parser.js.map +1 -0
- package/lib/parsers/rpc-parser.d.ts +8 -0
- package/lib/parsers/rpc-parser.js +13 -0
- package/lib/parsers/rpc-parser.js.map +1 -0
- package/lib/parsers/send-transaction-parser.d.ts +11 -0
- package/lib/parsers/send-transaction-parser.js +36 -0
- package/lib/parsers/send-transaction-parser.js.map +1 -0
- package/lib/provider/bridge/bridge-gateway.d.ts +18 -0
- package/lib/provider/bridge/bridge-gateway.js +79 -0
- package/lib/provider/bridge/bridge-gateway.js.map +1 -0
- package/lib/provider/bridge/bridge-provider.d.ts +27 -0
- package/lib/provider/bridge/bridge-provider.js +161 -0
- package/lib/provider/bridge/bridge-provider.js.map +1 -0
- package/lib/provider/bridge/models/bridge-connection.d.ts +11 -0
- package/lib/provider/bridge/models/bridge-connection.js +3 -0
- package/lib/provider/bridge/models/bridge-connection.js.map +1 -0
- package/lib/provider/bridge/models/bridge-incomming-message.d.ts +4 -0
- package/lib/provider/bridge/models/bridge-incomming-message.js +3 -0
- package/lib/provider/bridge/models/bridge-incomming-message.js.map +1 -0
- package/lib/provider/bridge/models/bridge-session-raw.d.ts +5 -0
- package/lib/provider/bridge/models/bridge-session-raw.js +3 -0
- package/lib/provider/bridge/models/bridge-session-raw.js.map +1 -0
- package/lib/provider/bridge/models/bridge-session.d.ts +8 -0
- package/lib/provider/bridge/models/bridge-session.js +3 -0
- package/lib/provider/bridge/models/bridge-session.js.map +1 -0
- package/lib/provider/injected/injected-provider.d.ts +21 -0
- package/lib/provider/injected/injected-provider.js +118 -0
- package/lib/provider/injected/injected-provider.js.map +1 -0
- package/lib/provider/injected/models/injected-wallet-api.d.ts +9 -0
- package/lib/provider/injected/models/injected-wallet-api.js +3 -0
- package/lib/provider/injected/models/injected-wallet-api.js.map +1 -0
- package/lib/provider/provider.d.ts +20 -0
- package/lib/provider/provider.js +3 -0
- package/lib/provider/provider.js.map +1 -0
- package/lib/resources/protocol.json +3 -0
- package/lib/storage/bridge-connection-storage.d.ts +11 -0
- package/lib/storage/bridge-connection-storage.js +76 -0
- package/lib/storage/bridge-connection-storage.js.map +1 -0
- package/lib/storage/default-storage.d.ts +7 -0
- package/lib/storage/default-storage.js +34 -0
- package/lib/storage/default-storage.js.map +1 -0
- package/lib/storage/models/storage.interface.d.ts +5 -0
- package/lib/storage/models/storage.interface.js +3 -0
- package/lib/storage/models/storage.interface.js.map +1 -0
- package/lib/ton-connect.d.ts +36 -0
- package/lib/ton-connect.interface.d.ts +13 -0
- package/lib/ton-connect.interface.js +3 -0
- package/lib/ton-connect.interface.js.map +1 -0
- package/lib/ton-connect.js +200 -0
- package/lib/ton-connect.js.map +1 -0
- package/lib/utils/options.d.ts +1 -0
- package/lib/utils/options.js +16 -0
- package/lib/utils/options.js.map +1 -0
- package/lib/utils/types.d.ts +6 -0
- package/lib/utils/types.js +3 -0
- package/lib/utils/types.js.map +1 -0
- package/lib/utils/web-api.d.ts +2 -0
- package/lib/utils/web-api.js +12 -0
- package/lib/utils/web-api.js.map +1 -0
- package/package.json +43 -0
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.InjectedProvider = void 0;
|
|
4
|
+
var tslib_1 = require("tslib");
|
|
5
|
+
var wallet_not_injected_error_1 = require("../../errors/wallet/wallet-not-injected.error");
|
|
6
|
+
var protocol = tslib_1.__importStar(require("../../resources/protocol.json"));
|
|
7
|
+
var InjectedProvider = /** @class */ (function () {
|
|
8
|
+
function InjectedProvider() {
|
|
9
|
+
this.type = 'injected';
|
|
10
|
+
this.unsubscribeCallback = null;
|
|
11
|
+
this.listenSubscriptions = false;
|
|
12
|
+
this.listeners = [];
|
|
13
|
+
if (!InjectedProvider.isWalletInjected()) {
|
|
14
|
+
throw new wallet_not_injected_error_1.WalletNotInjectedError();
|
|
15
|
+
}
|
|
16
|
+
this.injectedWallet = InjectedProvider.window.tonconnect;
|
|
17
|
+
}
|
|
18
|
+
InjectedProvider.isWalletInjected = function () {
|
|
19
|
+
return (InjectedProvider.window &&
|
|
20
|
+
'tonconnect' in InjectedProvider.window &&
|
|
21
|
+
typeof InjectedProvider.window.tonconnect === 'object');
|
|
22
|
+
};
|
|
23
|
+
InjectedProvider.deviceInfo = function () {
|
|
24
|
+
return InjectedProvider.isWalletInjected()
|
|
25
|
+
? InjectedProvider.window.tonconnect.deviceInfo
|
|
26
|
+
: undefined;
|
|
27
|
+
};
|
|
28
|
+
InjectedProvider.prototype.connect = function (message, auto) {
|
|
29
|
+
var _this = this;
|
|
30
|
+
if (auto === void 0) { auto = false; }
|
|
31
|
+
this.injectedWallet
|
|
32
|
+
.connect(protocol.version, message, auto)
|
|
33
|
+
.then(function (connectEvent) {
|
|
34
|
+
if (connectEvent.event === 'connect') {
|
|
35
|
+
_this.makeSubscriptions();
|
|
36
|
+
_this.listenSubscriptions = true;
|
|
37
|
+
}
|
|
38
|
+
_this.listeners.forEach(function (listener) { return listener(connectEvent); });
|
|
39
|
+
})
|
|
40
|
+
.catch(function (e) {
|
|
41
|
+
var connectEventError = {
|
|
42
|
+
event: 'connect_error',
|
|
43
|
+
payload: {
|
|
44
|
+
code: 0,
|
|
45
|
+
message: e === null || e === void 0 ? void 0 : e.toString()
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
_this.listeners.forEach(function (listener) { return listener(connectEventError); });
|
|
49
|
+
});
|
|
50
|
+
};
|
|
51
|
+
InjectedProvider.prototype.autoConnect = function () {
|
|
52
|
+
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
53
|
+
var connectEvent_1, e_1;
|
|
54
|
+
return tslib_1.__generator(this, function (_a) {
|
|
55
|
+
switch (_a.label) {
|
|
56
|
+
case 0:
|
|
57
|
+
_a.trys.push([0, 2, , 3]);
|
|
58
|
+
return [4 /*yield*/, this.injectedWallet.autoConnect()];
|
|
59
|
+
case 1:
|
|
60
|
+
connectEvent_1 = _a.sent();
|
|
61
|
+
if (connectEvent_1.event === 'connect') {
|
|
62
|
+
this.makeSubscriptions();
|
|
63
|
+
this.listenSubscriptions = true;
|
|
64
|
+
this.listeners.forEach(function (listener) { return listener(connectEvent_1); });
|
|
65
|
+
}
|
|
66
|
+
return [3 /*break*/, 3];
|
|
67
|
+
case 2:
|
|
68
|
+
e_1 = _a.sent();
|
|
69
|
+
console.error(e_1);
|
|
70
|
+
return [3 /*break*/, 3];
|
|
71
|
+
case 3: return [2 /*return*/];
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
};
|
|
76
|
+
InjectedProvider.prototype.closeConnection = function () {
|
|
77
|
+
var _a;
|
|
78
|
+
this.listenSubscriptions = false;
|
|
79
|
+
this.listeners = [];
|
|
80
|
+
(_a = this.unsubscribeCallback) === null || _a === void 0 ? void 0 : _a.call(this);
|
|
81
|
+
};
|
|
82
|
+
InjectedProvider.prototype.disconnect = function () {
|
|
83
|
+
var _a;
|
|
84
|
+
this.listenSubscriptions = false;
|
|
85
|
+
this.listeners = [];
|
|
86
|
+
(_a = this.unsubscribeCallback) === null || _a === void 0 ? void 0 : _a.call(this);
|
|
87
|
+
return Promise.resolve();
|
|
88
|
+
};
|
|
89
|
+
InjectedProvider.prototype.listen = function (eventsCallback) {
|
|
90
|
+
var _this = this;
|
|
91
|
+
this.listeners.push(eventsCallback);
|
|
92
|
+
return function () {
|
|
93
|
+
return (_this.listeners = _this.listeners.filter(function (listener) { return listener !== eventsCallback; }));
|
|
94
|
+
};
|
|
95
|
+
};
|
|
96
|
+
InjectedProvider.prototype.sendRequest = function (request) {
|
|
97
|
+
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
98
|
+
return tslib_1.__generator(this, function (_a) {
|
|
99
|
+
return [2 /*return*/, this.injectedWallet.send(tslib_1.__assign(tslib_1.__assign({}, request), { id: '0' }))];
|
|
100
|
+
});
|
|
101
|
+
});
|
|
102
|
+
};
|
|
103
|
+
InjectedProvider.prototype.makeSubscriptions = function () {
|
|
104
|
+
var _this = this;
|
|
105
|
+
this.unsubscribeCallback = this.injectedWallet.listen(function (e) {
|
|
106
|
+
if (_this.listenSubscriptions) {
|
|
107
|
+
_this.listeners.forEach(function (listener) { return listener(e); });
|
|
108
|
+
}
|
|
109
|
+
if (e.event === 'disconnect') {
|
|
110
|
+
_this.disconnect();
|
|
111
|
+
}
|
|
112
|
+
});
|
|
113
|
+
};
|
|
114
|
+
InjectedProvider.window = window;
|
|
115
|
+
return InjectedProvider;
|
|
116
|
+
}());
|
|
117
|
+
exports.InjectedProvider = InjectedProvider;
|
|
118
|
+
//# sourceMappingURL=injected-provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"injected-provider.js","sourceRoot":"","sources":["../../../src/provider/injected/injected-provider.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { AppRequest, ConnectEvent, ConnectRequest, DeviceInfo, RpcMethod, WalletEvent, WalletResponse } from '@tonconnect/protocol';
|
|
2
|
+
export interface InjectedWalletApi {
|
|
3
|
+
deviceInfo: DeviceInfo;
|
|
4
|
+
protocolVersion: number;
|
|
5
|
+
connect(protocolVersion: number, message: ConnectRequest, auto: boolean): Promise<ConnectEvent>;
|
|
6
|
+
autoConnect(): Promise<ConnectEvent>;
|
|
7
|
+
send<T extends RpcMethod>(message: AppRequest<T>): Promise<WalletResponse<T>>;
|
|
8
|
+
listen(callback: (event: WalletEvent) => void): () => void;
|
|
9
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"injected-wallet-api.js","sourceRoot":"","sources":["../../../../src/provider/injected/models/injected-wallet-api.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { AppRequest, ConnectRequest, RpcMethod, WalletEvent, WalletResponse } from '@tonconnect/protocol';
|
|
2
|
+
import { InjectedProvider } from "./injected/injected-provider";
|
|
3
|
+
import { WithoutId } from "../utils/types";
|
|
4
|
+
export declare type Provider = InjectedProvider | HTTPProvider;
|
|
5
|
+
export interface InternalProvider extends BaseProvider {
|
|
6
|
+
type: 'injected';
|
|
7
|
+
connect(message: ConnectRequest): void;
|
|
8
|
+
}
|
|
9
|
+
export interface HTTPProvider extends BaseProvider {
|
|
10
|
+
type: 'http';
|
|
11
|
+
connect(message: ConnectRequest): string;
|
|
12
|
+
}
|
|
13
|
+
interface BaseProvider {
|
|
14
|
+
autoConnect(): Promise<void>;
|
|
15
|
+
closeConnection(): void;
|
|
16
|
+
disconnect(): Promise<void>;
|
|
17
|
+
sendRequest<T extends RpcMethod>(request: WithoutId<AppRequest<T>>): Promise<WithoutId<WalletResponse<T>>>;
|
|
18
|
+
listen(eventsCallback: (e: WalletEvent) => void): void;
|
|
19
|
+
}
|
|
20
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider.js","sourceRoot":"","sources":["../../src/provider/provider.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { BridgeConnection } from "../provider/bridge/models/bridge-connection";
|
|
2
|
+
import { IStorage } from "./models/storage.interface";
|
|
3
|
+
export declare class BridgeConnectionStorage {
|
|
4
|
+
private readonly storage;
|
|
5
|
+
private readonly storeKey;
|
|
6
|
+
constructor(storage: IStorage);
|
|
7
|
+
storeConnection(connection: BridgeConnection): Promise<void>;
|
|
8
|
+
removeConnection(): Promise<void>;
|
|
9
|
+
getConnection(): Promise<BridgeConnection | null>;
|
|
10
|
+
storedConnectionExists(): Promise<boolean>;
|
|
11
|
+
}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BridgeConnectionStorage = void 0;
|
|
4
|
+
var tslib_1 = require("tslib");
|
|
5
|
+
var protocol_1 = require("@tonconnect/protocol");
|
|
6
|
+
var BridgeConnectionStorage = /** @class */ (function () {
|
|
7
|
+
function BridgeConnectionStorage(storage) {
|
|
8
|
+
this.storage = storage;
|
|
9
|
+
this.storeKey = 'ton-connect-storage_http-bridge-connection';
|
|
10
|
+
}
|
|
11
|
+
BridgeConnectionStorage.prototype.storeConnection = function (connection) {
|
|
12
|
+
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
13
|
+
var rawSession, rawConnection;
|
|
14
|
+
return tslib_1.__generator(this, function (_a) {
|
|
15
|
+
rawSession = {
|
|
16
|
+
sessionKeyPair: connection.session.sessionCrypto.stringifyKeypair(),
|
|
17
|
+
walletPublicKey: connection.session.walletPublicKey,
|
|
18
|
+
walletConnectionSource: connection.session.walletConnectionSource
|
|
19
|
+
};
|
|
20
|
+
rawConnection = {
|
|
21
|
+
session: rawSession,
|
|
22
|
+
connectEvent: connection.connectEvent
|
|
23
|
+
};
|
|
24
|
+
return [2 /*return*/, this.storage.setItem(this.storeKey, JSON.stringify(rawConnection))];
|
|
25
|
+
});
|
|
26
|
+
});
|
|
27
|
+
};
|
|
28
|
+
BridgeConnectionStorage.prototype.removeConnection = function () {
|
|
29
|
+
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
30
|
+
return tslib_1.__generator(this, function (_a) {
|
|
31
|
+
return [2 /*return*/, this.storage.removeItem(this.storeKey)];
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
};
|
|
35
|
+
BridgeConnectionStorage.prototype.getConnection = function () {
|
|
36
|
+
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
37
|
+
var stored, rawConnection, sessionCrypto;
|
|
38
|
+
return tslib_1.__generator(this, function (_a) {
|
|
39
|
+
switch (_a.label) {
|
|
40
|
+
case 0: return [4 /*yield*/, this.storage.getItem(this.storeKey)];
|
|
41
|
+
case 1:
|
|
42
|
+
stored = _a.sent();
|
|
43
|
+
if (!stored) {
|
|
44
|
+
return [2 /*return*/, null];
|
|
45
|
+
}
|
|
46
|
+
rawConnection = JSON.parse(stored);
|
|
47
|
+
sessionCrypto = new protocol_1.SessionCrypto(rawConnection.session.sessionKeyPair);
|
|
48
|
+
return [2 /*return*/, {
|
|
49
|
+
connectEvent: rawConnection.connectEvent,
|
|
50
|
+
session: {
|
|
51
|
+
sessionCrypto: sessionCrypto,
|
|
52
|
+
walletConnectionSource: rawConnection.session.walletConnectionSource,
|
|
53
|
+
walletPublicKey: rawConnection.session.walletPublicKey
|
|
54
|
+
}
|
|
55
|
+
}];
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
});
|
|
59
|
+
};
|
|
60
|
+
BridgeConnectionStorage.prototype.storedConnectionExists = function () {
|
|
61
|
+
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
62
|
+
var stored;
|
|
63
|
+
return tslib_1.__generator(this, function (_a) {
|
|
64
|
+
switch (_a.label) {
|
|
65
|
+
case 0: return [4 /*yield*/, this.storage.getItem(this.storeKey)];
|
|
66
|
+
case 1:
|
|
67
|
+
stored = _a.sent();
|
|
68
|
+
return [2 /*return*/, !!stored];
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
});
|
|
72
|
+
};
|
|
73
|
+
return BridgeConnectionStorage;
|
|
74
|
+
}());
|
|
75
|
+
exports.BridgeConnectionStorage = BridgeConnectionStorage;
|
|
76
|
+
//# sourceMappingURL=bridge-connection-storage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bridge-connection-storage.js","sourceRoot":"","sources":["../../src/storage/bridge-connection-storage.ts"],"names":[],"mappings":";;;;AAAA,iDAAqD;AAQrD;IAGI,iCAA6B,OAAiB;QAAjB,YAAO,GAAP,OAAO,CAAU;QAF7B,aAAQ,GAAG,4CAA4C,CAAC;IAExB,CAAC;IAErC,iDAAe,GAA5B,UAA6B,UAA4B;;;;gBAC/C,UAAU,GAAqB;oBACjC,cAAc,EAAE,UAAU,CAAC,OAAO,CAAC,aAAa,CAAC,gBAAgB,EAAE;oBACnE,eAAe,EAAE,UAAU,CAAC,OAAO,CAAC,eAAe;oBACnD,sBAAsB,EAAE,UAAU,CAAC,OAAO,CAAC,sBAAsB;iBACpE,CAAC;gBAEI,aAAa,GAAwB;oBACvC,OAAO,EAAE,UAAU;oBACnB,YAAY,EAAE,UAAU,CAAC,YAAY;iBACxC,CAAC;gBACF,sBAAO,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,EAAC;;;KAC7E;IAEY,kDAAgB,GAA7B;;;gBACI,sBAAO,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAC;;;KACjD;IAEY,+CAAa,GAA1B;;;;;4BACmB,qBAAM,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAA;;wBAAlD,MAAM,GAAG,SAAyC;wBACxD,IAAI,CAAC,MAAM,EAAE;4BACT,sBAAO,IAAI,EAAC;yBACf;wBAEK,aAAa,GAAwB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;wBACxD,aAAa,GAAG,IAAI,wBAAa,CAAC,aAAa,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;wBAC9E,sBAAO;gCACH,YAAY,EAAE,aAAa,CAAC,YAAY;gCACxC,OAAO,EAAE;oCACL,aAAa,eAAA;oCACb,sBAAsB,EAAE,aAAa,CAAC,OAAO,CAAC,sBAAsB;oCACpE,eAAe,EAAE,aAAa,CAAC,OAAO,CAAC,eAAe;iCACzD;6BACJ,EAAC;;;;KACL;IAEY,wDAAsB,GAAnC;;;;;4BACmB,qBAAM,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAA;;wBAAlD,MAAM,GAAG,SAAyC;wBACxD,sBAAO,CAAC,CAAC,MAAM,EAAC;;;;KACnB;IACL,8BAAC;AAAD,CAAC,AA7CD,IA6CC;AA7CY,0DAAuB"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { IStorage } from "./models/storage.interface";
|
|
2
|
+
export declare class DefaultStorage implements IStorage {
|
|
3
|
+
constructor();
|
|
4
|
+
getItem(key: string): Promise<string | null>;
|
|
5
|
+
removeItem(key: string): Promise<void>;
|
|
6
|
+
setItem(key: string, value: string): Promise<void>;
|
|
7
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DefaultStorage = void 0;
|
|
4
|
+
var tslib_1 = require("tslib");
|
|
5
|
+
var localstorage_not_found_error_1 = require("../errors/storage/localstorage-not-found.error");
|
|
6
|
+
var DefaultStorage = /** @class */ (function () {
|
|
7
|
+
function DefaultStorage() {
|
|
8
|
+
if (!(window === null || window === void 0 ? void 0 : window.localStorage)) {
|
|
9
|
+
throw new localstorage_not_found_error_1.LocalstorageNotFoundError();
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
DefaultStorage.prototype.getItem = function (key) {
|
|
13
|
+
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
14
|
+
return tslib_1.__generator(this, function (_a) {
|
|
15
|
+
return [2 /*return*/, Promise.resolve(window.localStorage.getItem(key))];
|
|
16
|
+
});
|
|
17
|
+
});
|
|
18
|
+
};
|
|
19
|
+
DefaultStorage.prototype.removeItem = function (key) {
|
|
20
|
+
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
21
|
+
return tslib_1.__generator(this, function (_a) {
|
|
22
|
+
window.localStorage.removeItem(key);
|
|
23
|
+
return [2 /*return*/, Promise.resolve()];
|
|
24
|
+
});
|
|
25
|
+
});
|
|
26
|
+
};
|
|
27
|
+
DefaultStorage.prototype.setItem = function (key, value) {
|
|
28
|
+
window.localStorage.setItem(key, value);
|
|
29
|
+
return Promise.resolve();
|
|
30
|
+
};
|
|
31
|
+
return DefaultStorage;
|
|
32
|
+
}());
|
|
33
|
+
exports.DefaultStorage = DefaultStorage;
|
|
34
|
+
//# sourceMappingURL=default-storage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"default-storage.js","sourceRoot":"","sources":["../../src/storage/default-storage.ts"],"names":[],"mappings":";;;;AAAA,+FAA4F;AAG5F;IACI;QACI,IAAI,CAAC,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,YAAY,CAAA,EAAE;YACvB,MAAM,IAAI,wDAAyB,EAAE,CAAC;SACzC;IACL,CAAC;IAEY,gCAAO,GAApB,UAAqB,GAAW;;;gBAC5B,sBAAO,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,EAAC;;;KAC5D;IAEY,mCAAU,GAAvB,UAAwB,GAAW;;;gBAC/B,MAAM,CAAC,YAAY,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;gBACpC,sBAAO,OAAO,CAAC,OAAO,EAAE,EAAC;;;KAC5B;IAED,gCAAO,GAAP,UAAQ,GAAW,EAAE,KAAa;QAC9B,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QACxC,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;IAC7B,CAAC;IACL,qBAAC;AAAD,CAAC,AApBD,IAoBC;AApBY,wCAAc"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"storage.interface.js","sourceRoot":"","sources":["../../../src/storage/models/storage.interface.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { TonConnectError } from "./errors/ton-connect.error";
|
|
2
|
+
import { Account, DappMetadata, Wallet, WalletConnectionSource } from "./models";
|
|
3
|
+
import { SendTransactionRequest, SendTransactionResponse } from "./models/methods";
|
|
4
|
+
import { InjectedProvider } from "./provider/injected/injected-provider";
|
|
5
|
+
import { IStorage } from "./storage/models/storage.interface";
|
|
6
|
+
import { ITonConnect } from "./ton-connect.interface";
|
|
7
|
+
export declare class TonConnect implements ITonConnect {
|
|
8
|
+
private readonly dappSettings;
|
|
9
|
+
private readonly bridgeConnectionStorage;
|
|
10
|
+
private _wallet;
|
|
11
|
+
private provider;
|
|
12
|
+
private statusChangeSubscriptions;
|
|
13
|
+
private statusChangeErrorSubscriptions;
|
|
14
|
+
get connected(): boolean;
|
|
15
|
+
get account(): Account | null;
|
|
16
|
+
get wallet(): Wallet | null;
|
|
17
|
+
private set wallet(value);
|
|
18
|
+
constructor(options?: {
|
|
19
|
+
dappMetedata?: DappMetadata;
|
|
20
|
+
storage?: IStorage;
|
|
21
|
+
});
|
|
22
|
+
onStatusChange(callback: (wallet: Wallet | null) => void, errorsHandler?: (err: TonConnectError) => void): () => void;
|
|
23
|
+
connect<T extends WalletConnectionSource | 'injected'>(wallet: T): T extends 'injected' ? void : string;
|
|
24
|
+
autoConnect(): void;
|
|
25
|
+
_autoConnect(): Promise<void>;
|
|
26
|
+
sendTransaction(tx: SendTransactionRequest): Promise<SendTransactionResponse>;
|
|
27
|
+
disconnect(): Promise<void>;
|
|
28
|
+
isInjectedProviderAvailable: typeof InjectedProvider.isWalletInjected;
|
|
29
|
+
private createProvider;
|
|
30
|
+
private walletEventsListener;
|
|
31
|
+
private onWalletConnected;
|
|
32
|
+
private onWalletConnectError;
|
|
33
|
+
private onWalletDisconnected;
|
|
34
|
+
private checkConnection;
|
|
35
|
+
private createConnectRequest;
|
|
36
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Account, WalletConnectionSource, Wallet } from "./models";
|
|
2
|
+
import { SendTransactionRequest, SendTransactionResponse } from "./models/methods";
|
|
3
|
+
export interface ITonConnect {
|
|
4
|
+
connected: boolean;
|
|
5
|
+
account: Account | null;
|
|
6
|
+
wallet: Wallet | null;
|
|
7
|
+
onStatusChange(callback: (walletInfo: Wallet | null) => void): () => void;
|
|
8
|
+
connect<T extends WalletConnectionSource | 'injected'>(wallet: T): T extends 'injected' ? void : string;
|
|
9
|
+
autoConnect(): void;
|
|
10
|
+
sendTransaction(tx: SendTransactionRequest): Promise<SendTransactionResponse>;
|
|
11
|
+
disconnect(): Promise<void>;
|
|
12
|
+
isInjectedProviderAvailable(): boolean;
|
|
13
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ton-connect.interface.js","sourceRoot":"","sources":["../src/ton-connect.interface.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TonConnect = void 0;
|
|
4
|
+
var tslib_1 = require("tslib");
|
|
5
|
+
var protocol_1 = require("@tonconnect/protocol");
|
|
6
|
+
var ton_connect_error_1 = require("./errors/ton-connect.error");
|
|
7
|
+
var wallet_already_connected_error_1 = require("./errors/wallet/wallet-already-connected.error");
|
|
8
|
+
var wallet_not_connected_error_1 = require("./errors/wallet/wallet-not-connected.error");
|
|
9
|
+
var connect_errors_parser_1 = require("./parsers/connect-errors-parser");
|
|
10
|
+
var send_transaction_parser_1 = require("./parsers/send-transaction-parser");
|
|
11
|
+
var bridge_provider_1 = require("./provider/bridge/bridge-provider");
|
|
12
|
+
var injected_provider_1 = require("./provider/injected/injected-provider");
|
|
13
|
+
var bridge_connection_storage_1 = require("./storage/bridge-connection-storage");
|
|
14
|
+
var default_storage_1 = require("./storage/default-storage");
|
|
15
|
+
var options_1 = require("./utils/options");
|
|
16
|
+
var web_api_1 = require("./utils/web-api");
|
|
17
|
+
var TonConnect = /** @class */ (function () {
|
|
18
|
+
function TonConnect(options) {
|
|
19
|
+
this._wallet = null;
|
|
20
|
+
this.provider = null;
|
|
21
|
+
this.statusChangeSubscriptions = [];
|
|
22
|
+
this.statusChangeErrorSubscriptions = [];
|
|
23
|
+
this.isInjectedProviderAvailable = injected_provider_1.InjectedProvider.isWalletInjected;
|
|
24
|
+
this.dappSettings = {
|
|
25
|
+
metadata: (options === null || options === void 0 ? void 0 : options.dappMetedata) || (0, web_api_1.getWebPageMetadata)(),
|
|
26
|
+
storage: (options === null || options === void 0 ? void 0 : options.storage) || new default_storage_1.DefaultStorage()
|
|
27
|
+
};
|
|
28
|
+
this.bridgeConnectionStorage = new bridge_connection_storage_1.BridgeConnectionStorage(this.dappSettings.storage);
|
|
29
|
+
}
|
|
30
|
+
Object.defineProperty(TonConnect.prototype, "connected", {
|
|
31
|
+
get: function () {
|
|
32
|
+
return this._wallet !== null;
|
|
33
|
+
},
|
|
34
|
+
enumerable: false,
|
|
35
|
+
configurable: true
|
|
36
|
+
});
|
|
37
|
+
Object.defineProperty(TonConnect.prototype, "account", {
|
|
38
|
+
get: function () {
|
|
39
|
+
var _a;
|
|
40
|
+
return ((_a = this._wallet) === null || _a === void 0 ? void 0 : _a.account) || null;
|
|
41
|
+
},
|
|
42
|
+
enumerable: false,
|
|
43
|
+
configurable: true
|
|
44
|
+
});
|
|
45
|
+
Object.defineProperty(TonConnect.prototype, "wallet", {
|
|
46
|
+
get: function () {
|
|
47
|
+
return this._wallet;
|
|
48
|
+
},
|
|
49
|
+
set: function (value) {
|
|
50
|
+
var _this = this;
|
|
51
|
+
this._wallet = value;
|
|
52
|
+
this.statusChangeSubscriptions.forEach(function (callback) { return callback(_this._wallet); });
|
|
53
|
+
},
|
|
54
|
+
enumerable: false,
|
|
55
|
+
configurable: true
|
|
56
|
+
});
|
|
57
|
+
TonConnect.prototype.onStatusChange = function (callback, errorsHandler) {
|
|
58
|
+
var _this = this;
|
|
59
|
+
this.statusChangeSubscriptions.push(callback);
|
|
60
|
+
if (errorsHandler) {
|
|
61
|
+
this.statusChangeErrorSubscriptions.push(errorsHandler);
|
|
62
|
+
}
|
|
63
|
+
return function () {
|
|
64
|
+
_this.statusChangeSubscriptions = _this.statusChangeSubscriptions.filter(function (item) { return item !== callback; });
|
|
65
|
+
if (errorsHandler) {
|
|
66
|
+
_this.statusChangeErrorSubscriptions = _this.statusChangeErrorSubscriptions.filter(function (item) { return item !== errorsHandler; });
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
};
|
|
70
|
+
TonConnect.prototype.connect = function (wallet) {
|
|
71
|
+
var _a;
|
|
72
|
+
if (this.connected) {
|
|
73
|
+
throw new wallet_already_connected_error_1.WalletAlreadyConnectedError();
|
|
74
|
+
}
|
|
75
|
+
(_a = this.provider) === null || _a === void 0 ? void 0 : _a.closeConnection();
|
|
76
|
+
this.provider = this.createProvider(wallet);
|
|
77
|
+
return this.provider.connect(this.createConnectRequest());
|
|
78
|
+
};
|
|
79
|
+
TonConnect.prototype.autoConnect = function () {
|
|
80
|
+
this._autoConnect();
|
|
81
|
+
};
|
|
82
|
+
TonConnect.prototype._autoConnect = function () {
|
|
83
|
+
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
84
|
+
var bridgeConnection, provider;
|
|
85
|
+
return tslib_1.__generator(this, function (_a) {
|
|
86
|
+
switch (_a.label) {
|
|
87
|
+
case 0: return [4 /*yield*/, this.bridgeConnectionStorage.getConnection()];
|
|
88
|
+
case 1:
|
|
89
|
+
bridgeConnection = _a.sent();
|
|
90
|
+
if (!bridgeConnection) return [3 /*break*/, 3];
|
|
91
|
+
return [4 /*yield*/, this.createProvider(bridgeConnection.session.walletConnectionSource)];
|
|
92
|
+
case 2:
|
|
93
|
+
provider = _a.sent();
|
|
94
|
+
return [3 /*break*/, 5];
|
|
95
|
+
case 3: return [4 /*yield*/, this.createProvider('injected')];
|
|
96
|
+
case 4:
|
|
97
|
+
provider = _a.sent();
|
|
98
|
+
_a.label = 5;
|
|
99
|
+
case 5: return [2 /*return*/, provider.autoConnect()];
|
|
100
|
+
}
|
|
101
|
+
});
|
|
102
|
+
});
|
|
103
|
+
};
|
|
104
|
+
TonConnect.prototype.sendTransaction = function (tx) {
|
|
105
|
+
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
106
|
+
var response;
|
|
107
|
+
return tslib_1.__generator(this, function (_a) {
|
|
108
|
+
switch (_a.label) {
|
|
109
|
+
case 0:
|
|
110
|
+
this.checkConnection();
|
|
111
|
+
return [4 /*yield*/, this.provider.sendRequest(send_transaction_parser_1.sendTransactionParser.convertToRpcRequest(tx))];
|
|
112
|
+
case 1:
|
|
113
|
+
response = _a.sent();
|
|
114
|
+
if (send_transaction_parser_1.sendTransactionParser.isError(response)) {
|
|
115
|
+
return [2 /*return*/, send_transaction_parser_1.sendTransactionParser.parseAndThrowError(response)];
|
|
116
|
+
}
|
|
117
|
+
return [2 /*return*/, send_transaction_parser_1.sendTransactionParser.convertFromRpcResponse(response)];
|
|
118
|
+
}
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
};
|
|
122
|
+
TonConnect.prototype.disconnect = function () {
|
|
123
|
+
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
124
|
+
return tslib_1.__generator(this, function (_a) {
|
|
125
|
+
switch (_a.label) {
|
|
126
|
+
case 0:
|
|
127
|
+
if (!this.connected) {
|
|
128
|
+
throw new wallet_not_connected_error_1.WalletNotConnectedError();
|
|
129
|
+
}
|
|
130
|
+
return [4 /*yield*/, this.provider.disconnect()];
|
|
131
|
+
case 1:
|
|
132
|
+
_a.sent();
|
|
133
|
+
this.onWalletDisconnected();
|
|
134
|
+
return [2 /*return*/];
|
|
135
|
+
}
|
|
136
|
+
});
|
|
137
|
+
});
|
|
138
|
+
};
|
|
139
|
+
TonConnect.prototype.createProvider = function (wallet) {
|
|
140
|
+
var provider;
|
|
141
|
+
if (wallet === 'injected') {
|
|
142
|
+
provider = new injected_provider_1.InjectedProvider();
|
|
143
|
+
}
|
|
144
|
+
else {
|
|
145
|
+
provider = new bridge_provider_1.BridgeProvider(this.dappSettings.storage, wallet);
|
|
146
|
+
}
|
|
147
|
+
provider.listen(this.walletEventsListener.bind(this));
|
|
148
|
+
return provider;
|
|
149
|
+
};
|
|
150
|
+
TonConnect.prototype.walletEventsListener = function (e) {
|
|
151
|
+
switch (e.event) {
|
|
152
|
+
case 'connect':
|
|
153
|
+
this.onWalletConnected(e.payload);
|
|
154
|
+
break;
|
|
155
|
+
case 'connect_error':
|
|
156
|
+
this.onWalletConnectError(e.payload);
|
|
157
|
+
break;
|
|
158
|
+
case 'disconnect':
|
|
159
|
+
this.onWalletDisconnected();
|
|
160
|
+
}
|
|
161
|
+
};
|
|
162
|
+
TonConnect.prototype.onWalletConnected = function (connectEvent) {
|
|
163
|
+
var tonAccountItem = connectEvent.items.find(function (item) { return item.name === 'ton_addr'; });
|
|
164
|
+
if (!tonAccountItem) {
|
|
165
|
+
throw new ton_connect_error_1.TonConnectError('ton_addr connection item was not found');
|
|
166
|
+
}
|
|
167
|
+
this.wallet = {
|
|
168
|
+
device: connectEvent.device,
|
|
169
|
+
provider: this.provider.type,
|
|
170
|
+
account: {
|
|
171
|
+
address: tonAccountItem.address,
|
|
172
|
+
chain: protocol_1.CHAIN.MAINNET // TODO
|
|
173
|
+
}
|
|
174
|
+
};
|
|
175
|
+
};
|
|
176
|
+
TonConnect.prototype.onWalletConnectError = function (connectEventError) {
|
|
177
|
+
var error = connect_errors_parser_1.connectErrorsParser.parseError(connectEventError);
|
|
178
|
+
this.statusChangeErrorSubscriptions.forEach(function (errorsHandler) { return errorsHandler(error); });
|
|
179
|
+
};
|
|
180
|
+
TonConnect.prototype.onWalletDisconnected = function () {
|
|
181
|
+
this.wallet = null;
|
|
182
|
+
};
|
|
183
|
+
TonConnect.prototype.checkConnection = function () {
|
|
184
|
+
if (!this.connected) {
|
|
185
|
+
throw new wallet_not_connected_error_1.WalletNotConnectedError();
|
|
186
|
+
}
|
|
187
|
+
};
|
|
188
|
+
TonConnect.prototype.createConnectRequest = function () {
|
|
189
|
+
var webPageMetadata = (0, web_api_1.getWebPageMetadata)();
|
|
190
|
+
var metadata = (0, options_1.mergeOptions)(this.dappSettings.metadata, webPageMetadata);
|
|
191
|
+
return tslib_1.__assign(tslib_1.__assign({}, metadata), { items: [
|
|
192
|
+
{
|
|
193
|
+
name: 'ton_addr'
|
|
194
|
+
}
|
|
195
|
+
] });
|
|
196
|
+
};
|
|
197
|
+
return TonConnect;
|
|
198
|
+
}());
|
|
199
|
+
exports.TonConnect = TonConnect;
|
|
200
|
+
//# sourceMappingURL=ton-connect.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ton-connect.js","sourceRoot":"","sources":["../src/ton-connect.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function mergeOptions<T>(options: Partial<T> | undefined | null, defaultOptions: T): T;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.mergeOptions = void 0;
|
|
4
|
+
var tslib_1 = require("tslib");
|
|
5
|
+
var deepmerge_1 = tslib_1.__importDefault(require("deepmerge"));
|
|
6
|
+
function mergeOptions(options, defaultOptions) {
|
|
7
|
+
if (!options) {
|
|
8
|
+
return defaultOptions;
|
|
9
|
+
}
|
|
10
|
+
var overwriteMerge = function (_, sourceArray, __) {
|
|
11
|
+
return sourceArray;
|
|
12
|
+
};
|
|
13
|
+
return (0, deepmerge_1.default)(options, defaultOptions, { arrayMerge: overwriteMerge });
|
|
14
|
+
}
|
|
15
|
+
exports.mergeOptions = mergeOptions;
|
|
16
|
+
//# sourceMappingURL=options.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"options.js","sourceRoot":"","sources":["../../src/utils/options.ts"],"names":[],"mappings":";;;;AAAA,gEAAkC;AAElC,SAAgB,YAAY,CAAI,OAAsC,EAAE,cAAiB;IACrF,IAAI,CAAC,OAAO,EAAE;QACV,OAAO,cAAc,CAAC;KACzB;IAED,IAAM,cAAc,GAAG,UAAC,CAAY,EAAE,WAAsB,EAAE,EAAW;QACrE,OAAA,WAAW;IAAX,CAAW,CAAC;IAEhB,OAAO,IAAA,mBAAS,EAAC,OAAO,EAAE,cAAc,EAAE,EAAE,UAAU,EAAE,cAAc,EAAE,CAAC,CAAC;AAC9E,CAAC;AATD,oCASC"}
|