@ledgerhq/ledger-key-ring-protocol 0.5.1-fix-build-number-pre.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/.eslintrc.js +33 -0
- package/.turbo/turbo-build.log +4 -0
- package/CHANGELOG.md +299 -0
- package/LICENSE.txt +21 -0
- package/README.md +3 -0
- package/jest.config.js +13 -0
- package/lib/HWDeviceProvider.d.ts +25 -0
- package/lib/HWDeviceProvider.d.ts.map +1 -0
- package/lib/HWDeviceProvider.js +88 -0
- package/lib/HWDeviceProvider.js.map +1 -0
- package/lib/api.d.ts +77 -0
- package/lib/api.d.ts.map +1 -0
- package/lib/api.js +150 -0
- package/lib/api.js.map +1 -0
- package/lib/auth.d.ts +3 -0
- package/lib/auth.d.ts.map +1 -0
- package/lib/auth.js +79 -0
- package/lib/auth.js.map +1 -0
- package/lib/errors.d.ts +40 -0
- package/lib/errors.d.ts.map +1 -0
- package/lib/errors.js +18 -0
- package/lib/errors.js.map +1 -0
- package/lib/index.d.ts +6 -0
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +17 -0
- package/lib/index.js.map +1 -0
- package/lib/mockSdk.d.ts +22 -0
- package/lib/mockSdk.d.ts.map +1 -0
- package/lib/mockSdk.js +208 -0
- package/lib/mockSdk.js.map +1 -0
- package/lib/qrcode/cipher.d.ts +12 -0
- package/lib/qrcode/cipher.d.ts.map +1 -0
- package/lib/qrcode/cipher.js +52 -0
- package/lib/qrcode/cipher.js.map +1 -0
- package/lib/qrcode/cipher.test.d.ts +2 -0
- package/lib/qrcode/cipher.test.d.ts.map +1 -0
- package/lib/qrcode/cipher.test.js +31 -0
- package/lib/qrcode/cipher.test.js.map +1 -0
- package/lib/qrcode/index.d.ts +70 -0
- package/lib/qrcode/index.d.ts.map +1 -0
- package/lib/qrcode/index.js +309 -0
- package/lib/qrcode/index.js.map +1 -0
- package/lib/qrcode/index.test.d.ts +2 -0
- package/lib/qrcode/index.test.d.ts.map +1 -0
- package/lib/qrcode/index.test.js +131 -0
- package/lib/qrcode/index.test.js.map +1 -0
- package/lib/qrcode/types.d.ts +69 -0
- package/lib/qrcode/types.d.ts.map +1 -0
- package/lib/qrcode/types.js +3 -0
- package/lib/qrcode/types.js.map +1 -0
- package/lib/sdk.d.ts +31 -0
- package/lib/sdk.d.ts.map +1 -0
- package/lib/sdk.js +380 -0
- package/lib/sdk.js.map +1 -0
- package/lib/store.d.ts +71 -0
- package/lib/store.d.ts.map +1 -0
- package/lib/store.js +62 -0
- package/lib/store.js.map +1 -0
- package/lib/types.d.ts +181 -0
- package/lib/types.d.ts.map +1 -0
- package/lib/types.js +10 -0
- package/lib/types.js.map +1 -0
- package/lib-es/HWDeviceProvider.d.ts +25 -0
- package/lib-es/HWDeviceProvider.d.ts.map +1 -0
- package/lib-es/HWDeviceProvider.js +81 -0
- package/lib-es/HWDeviceProvider.js.map +1 -0
- package/lib-es/api.d.ts +77 -0
- package/lib-es/api.d.ts.map +1 -0
- package/lib-es/api.js +145 -0
- package/lib-es/api.js.map +1 -0
- package/lib-es/auth.d.ts +3 -0
- package/lib-es/auth.d.ts.map +1 -0
- package/lib-es/auth.js +75 -0
- package/lib-es/auth.js.map +1 -0
- package/lib-es/errors.d.ts +40 -0
- package/lib-es/errors.d.ts.map +1 -0
- package/lib-es/errors.js +15 -0
- package/lib-es/errors.js.map +1 -0
- package/lib-es/index.d.ts +6 -0
- package/lib-es/index.d.ts.map +1 -0
- package/lib-es/index.js +13 -0
- package/lib-es/index.js.map +1 -0
- package/lib-es/mockSdk.d.ts +22 -0
- package/lib-es/mockSdk.d.ts.map +1 -0
- package/lib-es/mockSdk.js +201 -0
- package/lib-es/mockSdk.js.map +1 -0
- package/lib-es/qrcode/cipher.d.ts +12 -0
- package/lib-es/qrcode/cipher.d.ts.map +1 -0
- package/lib-es/qrcode/cipher.js +44 -0
- package/lib-es/qrcode/cipher.js.map +1 -0
- package/lib-es/qrcode/cipher.test.d.ts +2 -0
- package/lib-es/qrcode/cipher.test.d.ts.map +1 -0
- package/lib-es/qrcode/cipher.test.js +29 -0
- package/lib-es/qrcode/cipher.test.js.map +1 -0
- package/lib-es/qrcode/index.d.ts +70 -0
- package/lib-es/qrcode/index.d.ts.map +1 -0
- package/lib-es/qrcode/index.js +301 -0
- package/lib-es/qrcode/index.js.map +1 -0
- package/lib-es/qrcode/index.test.d.ts +2 -0
- package/lib-es/qrcode/index.test.d.ts.map +1 -0
- package/lib-es/qrcode/index.test.js +126 -0
- package/lib-es/qrcode/index.test.js.map +1 -0
- package/lib-es/qrcode/types.d.ts +69 -0
- package/lib-es/qrcode/types.d.ts.map +1 -0
- package/lib-es/qrcode/types.js +2 -0
- package/lib-es/qrcode/types.js.map +1 -0
- package/lib-es/sdk.d.ts +31 -0
- package/lib-es/sdk.d.ts.map +1 -0
- package/lib-es/sdk.js +371 -0
- package/lib-es/sdk.js.map +1 -0
- package/lib-es/store.d.ts +71 -0
- package/lib-es/store.d.ts.map +1 -0
- package/lib-es/store.js +51 -0
- package/lib-es/store.js.map +1 -0
- package/lib-es/types.d.ts +181 -0
- package/lib-es/types.d.ts.map +1 -0
- package/lib-es/types.js +7 -0
- package/lib-es/types.js.map +1 -0
- package/mocks/scenarios/addSameMemberMultipleTimes.json +426 -0
- package/mocks/scenarios/create2trustchainInARow.json +616 -0
- package/mocks/scenarios/getOrCreateTransactionCases.json +591 -0
- package/mocks/scenarios/member3implicitlyAdded.json +648 -0
- package/mocks/scenarios/membersManySelfAdd.json +1427 -0
- package/mocks/scenarios/randomMemberTryToDestroy.json +371 -0
- package/mocks/scenarios/removeMemberWithTheWrongSeed.json +510 -0
- package/mocks/scenarios/removedMemberEjectedOnDeletedTrustchain.json +481 -0
- package/mocks/scenarios/removedMemberEjectedOnGetMembers.json +648 -0
- package/mocks/scenarios/removedMemberEjectedOnRestore.json +648 -0
- package/mocks/scenarios/removingAMemberCreatesAnInteraction.json +593 -0
- package/mocks/scenarios/removingYourselfIsForbidden.json +397 -0
- package/mocks/scenarios/success.json +978 -0
- package/mocks/scenarios/tokenExpires.json +371 -0
- package/mocks/scenarios/twoAddMembersFollowedByDeviceAdd.json +705 -0
- package/mocks/scenarios/userRefusesAuth.json +40 -0
- package/mocks/scenarios/userRefusesRemoveMember.json +542 -0
- package/package.json +91 -0
- package/scripts/README.md +15 -0
- package/scripts/e2e.ts +57 -0
- package/src/HWDeviceProvider.ts +105 -0
- package/src/__tests__/integration/mock.sdk.test.ts +47 -0
- package/src/__tests__/integration/sdk.test.ts +20 -0
- package/src/__tests__/tsconfig.json +8 -0
- package/src/__tests__/unit/sdk.test.ts +236 -0
- package/src/api.ts +202 -0
- package/src/auth.ts +81 -0
- package/src/errors.ts +18 -0
- package/src/index.ts +20 -0
- package/src/mockSdk.ts +253 -0
- package/src/qrcode/cipher.test.ts +30 -0
- package/src/qrcode/cipher.ts +61 -0
- package/src/qrcode/index.test.ts +138 -0
- package/src/qrcode/index.ts +394 -0
- package/src/qrcode/types.ts +70 -0
- package/src/sdk.ts +542 -0
- package/src/store.ts +99 -0
- package/src/types.ts +242 -0
- package/tests/scenarios/_template.ts +18 -0
- package/tests/scenarios/addSameMemberMultipleTimes.ts +20 -0
- package/tests/scenarios/create2trustchainInARow.ts +14 -0
- package/tests/scenarios/getOrCreateTransactionCases.ts +74 -0
- package/tests/scenarios/member3implicitlyAdded.ts +51 -0
- package/tests/scenarios/membersManySelfAdd.ts +18 -0
- package/tests/scenarios/randomMemberTryToDestroy.ts +23 -0
- package/tests/scenarios/removeMemberWithTheWrongSeed.ts +28 -0
- package/tests/scenarios/removedMemberEjectedOnDeletedTrustchain.ts +31 -0
- package/tests/scenarios/removedMemberEjectedOnGetMembers.ts +29 -0
- package/tests/scenarios/removedMemberEjectedOnRestore.ts +31 -0
- package/tests/scenarios/removingAMemberCreatesAnInteraction.ts +42 -0
- package/tests/scenarios/removingYourselfIsForbidden.ts +11 -0
- package/tests/scenarios/success.ts +94 -0
- package/tests/scenarios/tokenExpires.ts +20 -0
- package/tests/scenarios/twoAddMembersFollowedByDeviceAdd.ts +49 -0
- package/tests/scenarios/userRefusesAuth.ts +28 -0
- package/tests/scenarios/userRefusesRemoveMember.ts +66 -0
- package/tests/test-helpers/recordTrustchainSdkTests.ts +178 -0
- package/tests/test-helpers/replayTrustchainSdkTests.ts +141 -0
- package/tests/test-helpers/types.ts +45 -0
- package/tests/tsconfig.json +8 -0
- package/tsconfig.json +15 -0
|
@@ -0,0 +1,301 @@
|
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
import { Permissions, crypto } from "@ledgerhq/hw-ledger-key-ring-protocol";
|
|
11
|
+
import WebSocket from "isomorphic-ws";
|
|
12
|
+
import { makeCipher, makeMessageCipher } from "./cipher";
|
|
13
|
+
import { InvalidDigitsError, NoTrustchainInitialized, QRCodeWSClosed, ScannedInvalidQrCode, ScannedOldImportQrCode, TrustchainAlreadyInitialized, } from "../errors";
|
|
14
|
+
import { log } from "@ledgerhq/logs";
|
|
15
|
+
const version = 1;
|
|
16
|
+
const CLOSE_TIMEOUT = 100; // just enough time for the onerror to appear before onclose
|
|
17
|
+
const commonSwitch = (_a) => __awaiter(void 0, [_a], void 0, function* ({ data, cipher, addMember, send, publisher, resolve, memberCredentials, memberName, reject, ws, setFinished, initialTrustchainId, }) {
|
|
18
|
+
switch (data.message) {
|
|
19
|
+
case "TrustchainShareCredential": {
|
|
20
|
+
if (!initialTrustchainId) {
|
|
21
|
+
const payload = {
|
|
22
|
+
type: "UNEXPECTED_SHARE_CREDENTIAL",
|
|
23
|
+
message: "unexpected share credential",
|
|
24
|
+
};
|
|
25
|
+
send({ version, publisher, message: "Failure", payload });
|
|
26
|
+
throw new NoTrustchainInitialized("unexpected share credential");
|
|
27
|
+
}
|
|
28
|
+
setFinished(true);
|
|
29
|
+
if (!cipher) {
|
|
30
|
+
throw new Error("sessionEncryptionKey not set");
|
|
31
|
+
}
|
|
32
|
+
const { id, name } = cipher.decryptMessage(data);
|
|
33
|
+
const trustchain = yield addMember({ id, name, permissions: Permissions.OWNER });
|
|
34
|
+
const payload = cipher.encryptMessagePayload({ trustchain });
|
|
35
|
+
send({ version, publisher, message: "TrustchainAddedMember", payload });
|
|
36
|
+
resolve();
|
|
37
|
+
break;
|
|
38
|
+
}
|
|
39
|
+
case "TrustchainRequestCredential": {
|
|
40
|
+
if (initialTrustchainId) {
|
|
41
|
+
const payload = {
|
|
42
|
+
type: "UNEXPECTED_REQUEST_CREDENTIAL",
|
|
43
|
+
message: initialTrustchainId,
|
|
44
|
+
};
|
|
45
|
+
send({ version, publisher, message: "Failure", payload });
|
|
46
|
+
throw new TrustchainAlreadyInitialized(initialTrustchainId);
|
|
47
|
+
}
|
|
48
|
+
const payload = cipher.encryptMessagePayload({
|
|
49
|
+
id: memberCredentials.pubkey,
|
|
50
|
+
name: memberName,
|
|
51
|
+
});
|
|
52
|
+
send({ version, publisher, message: "TrustchainShareCredential", payload });
|
|
53
|
+
break;
|
|
54
|
+
}
|
|
55
|
+
case "TrustchainAddedMember": {
|
|
56
|
+
setFinished(true);
|
|
57
|
+
const { trustchain } = cipher.decryptMessage(data);
|
|
58
|
+
resolve(trustchain);
|
|
59
|
+
ws.close();
|
|
60
|
+
break;
|
|
61
|
+
}
|
|
62
|
+
case "Failure": {
|
|
63
|
+
setFinished(true);
|
|
64
|
+
log("trustchain/qrcode", "Failure", { data });
|
|
65
|
+
const error = fromErrorMessage(data.payload);
|
|
66
|
+
reject(error);
|
|
67
|
+
ws.close();
|
|
68
|
+
break;
|
|
69
|
+
}
|
|
70
|
+
case "HandshakeChallenge":
|
|
71
|
+
case "HandshakeCompletionSucceeded":
|
|
72
|
+
case "InitiateHandshake":
|
|
73
|
+
case "CompleteHandshakeChallenge":
|
|
74
|
+
break;
|
|
75
|
+
default:
|
|
76
|
+
throw new Error("unexpected message");
|
|
77
|
+
}
|
|
78
|
+
});
|
|
79
|
+
/**
|
|
80
|
+
* establish a channel to be able to add a member to the trustchain after displaying the QR Code
|
|
81
|
+
* @returns a promise that resolves when this is done
|
|
82
|
+
*/
|
|
83
|
+
export function createQRCodeHostInstance(_a) {
|
|
84
|
+
return __awaiter(this, arguments, void 0, function* ({ trustchainApiBaseUrl, onDisplayQRCode, onDisplayDigits, addMember, memberCredentials, memberName, initialTrustchainId, }) {
|
|
85
|
+
const ephemeralKey = crypto.randomKeypair();
|
|
86
|
+
const publisher = crypto.to_hex(ephemeralKey.publicKey);
|
|
87
|
+
const url = `${trustchainApiBaseUrl.replace("http", "ws")}/v1/qr?host=${publisher}`;
|
|
88
|
+
const ws = new WebSocket(url);
|
|
89
|
+
function send(message) {
|
|
90
|
+
ws.send(JSON.stringify(message));
|
|
91
|
+
}
|
|
92
|
+
let sessionEncryptionKey;
|
|
93
|
+
let cipher;
|
|
94
|
+
let expectedDigits;
|
|
95
|
+
let finished = false;
|
|
96
|
+
const setFinished = newValue => (finished = newValue);
|
|
97
|
+
onDisplayQRCode(url);
|
|
98
|
+
return new Promise((resolve, reject) => {
|
|
99
|
+
const startedAt = Date.now();
|
|
100
|
+
ws.addEventListener("error", reject);
|
|
101
|
+
ws.addEventListener("close", () => {
|
|
102
|
+
if (finished)
|
|
103
|
+
return;
|
|
104
|
+
// this error would reflect a protocol error. because otherwise, we would get the "error" event.
|
|
105
|
+
const time = Date.now() - startedAt;
|
|
106
|
+
reject(new QRCodeWSClosed("qrcode websocket prematurely closed", { time }));
|
|
107
|
+
});
|
|
108
|
+
ws.addEventListener("message", (e) => __awaiter(this, void 0, void 0, function* () {
|
|
109
|
+
try {
|
|
110
|
+
const data = parseMessage(e.data);
|
|
111
|
+
switch (data.message) {
|
|
112
|
+
case "InitiateHandshake": {
|
|
113
|
+
const candidatePublicKey = crypto.from_hex(data.payload.ephemeral_public_key);
|
|
114
|
+
sessionEncryptionKey = crypto.ecdh(ephemeralKey, candidatePublicKey);
|
|
115
|
+
cipher = makeMessageCipher(makeCipher(sessionEncryptionKey));
|
|
116
|
+
// --- end of handshake first phase ---
|
|
117
|
+
const digitsCount = 3;
|
|
118
|
+
const digits = randomDigits(digitsCount);
|
|
119
|
+
expectedDigits = digits;
|
|
120
|
+
onDisplayDigits(digits);
|
|
121
|
+
const payload = cipher.encryptMessagePayload({
|
|
122
|
+
digits: digitsCount,
|
|
123
|
+
connected: false,
|
|
124
|
+
});
|
|
125
|
+
send({ version, publisher, message: "HandshakeChallenge", payload });
|
|
126
|
+
break;
|
|
127
|
+
}
|
|
128
|
+
case "CompleteHandshakeChallenge": {
|
|
129
|
+
if (!cipher) {
|
|
130
|
+
throw new Error("sessionEncryptionKey not set");
|
|
131
|
+
}
|
|
132
|
+
const { digits } = cipher.decryptMessage(data);
|
|
133
|
+
if (digits !== expectedDigits) {
|
|
134
|
+
console.warn("User invalid digits", { digits, expectedDigits });
|
|
135
|
+
const payload = {
|
|
136
|
+
type: "HANDSHAKE_COMPLETION_FAILED",
|
|
137
|
+
message: "invalid digits",
|
|
138
|
+
};
|
|
139
|
+
send({ version, publisher, message: "Failure", payload });
|
|
140
|
+
throw new InvalidDigitsError("invalid digits");
|
|
141
|
+
}
|
|
142
|
+
const payload = cipher.encryptMessagePayload({});
|
|
143
|
+
send({ version, publisher, message: "HandshakeCompletionSucceeded", payload });
|
|
144
|
+
break;
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
yield commonSwitch({
|
|
148
|
+
data,
|
|
149
|
+
cipher,
|
|
150
|
+
addMember,
|
|
151
|
+
send,
|
|
152
|
+
publisher,
|
|
153
|
+
resolve,
|
|
154
|
+
memberCredentials,
|
|
155
|
+
memberName,
|
|
156
|
+
reject,
|
|
157
|
+
ws,
|
|
158
|
+
setFinished,
|
|
159
|
+
initialTrustchainId,
|
|
160
|
+
});
|
|
161
|
+
}
|
|
162
|
+
catch (e) {
|
|
163
|
+
console.error("socket error", e);
|
|
164
|
+
ws.close();
|
|
165
|
+
reject(e);
|
|
166
|
+
}
|
|
167
|
+
}));
|
|
168
|
+
});
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
/**
|
|
172
|
+
* establish a channel to be able to add myself to the trustchain after scanning the QR Code
|
|
173
|
+
* @returns a promise that resolves a Trustchain when this is done
|
|
174
|
+
*/
|
|
175
|
+
export function createQRCodeCandidateInstance(_a) {
|
|
176
|
+
return __awaiter(this, arguments, void 0, function* ({ memberCredentials, memberName, addMember, initialTrustchainId, scannedUrl, onRequestQRCodeInput, }) {
|
|
177
|
+
const m = scannedUrl.match(/host=([0-9A-Fa-f]+)/);
|
|
178
|
+
if (!m) {
|
|
179
|
+
if (isFromOldAccountsImport(scannedUrl))
|
|
180
|
+
throw new ScannedOldImportQrCode();
|
|
181
|
+
throw new ScannedInvalidQrCode();
|
|
182
|
+
}
|
|
183
|
+
const hostPublicKey = crypto.from_hex(m[1]);
|
|
184
|
+
const ephemeralKey = crypto.randomKeypair();
|
|
185
|
+
const publisher = crypto.to_hex(ephemeralKey.publicKey);
|
|
186
|
+
const sessionEncryptionKey = crypto.ecdh(ephemeralKey, hostPublicKey);
|
|
187
|
+
const cipher = makeMessageCipher(makeCipher(sessionEncryptionKey));
|
|
188
|
+
const ws = new WebSocket(scannedUrl);
|
|
189
|
+
function send(message) {
|
|
190
|
+
ws.send(JSON.stringify(message));
|
|
191
|
+
}
|
|
192
|
+
let finished = false;
|
|
193
|
+
const setFinished = newValue => (finished = newValue);
|
|
194
|
+
return new Promise((resolve, reject) => {
|
|
195
|
+
ws.addEventListener("close", () => {
|
|
196
|
+
if (finished)
|
|
197
|
+
return;
|
|
198
|
+
// this error would reflect a protocol error. because otherwise, we would get the "error" event. it shouldn't be visible to user, but we use it to ensure the promise ends.
|
|
199
|
+
setTimeout(() => reject(new Error("qrcode websocket prematurely closed")), CLOSE_TIMEOUT);
|
|
200
|
+
});
|
|
201
|
+
ws.addEventListener("message", (e) => __awaiter(this, void 0, void 0, function* () {
|
|
202
|
+
try {
|
|
203
|
+
const data = parseMessage(e.data);
|
|
204
|
+
switch (data.message) {
|
|
205
|
+
case "HandshakeChallenge": {
|
|
206
|
+
const config = cipher.decryptMessage(data);
|
|
207
|
+
onRequestQRCodeInput(config, digits => {
|
|
208
|
+
const payload = cipher.encryptMessagePayload({ digits });
|
|
209
|
+
send({ version, publisher, message: "CompleteHandshakeChallenge", payload });
|
|
210
|
+
});
|
|
211
|
+
break;
|
|
212
|
+
}
|
|
213
|
+
case "HandshakeCompletionSucceeded": {
|
|
214
|
+
if (initialTrustchainId) {
|
|
215
|
+
const payload = cipher.encryptMessagePayload({});
|
|
216
|
+
send({ version, publisher, message: "TrustchainRequestCredential", payload });
|
|
217
|
+
}
|
|
218
|
+
else {
|
|
219
|
+
const payload = cipher.encryptMessagePayload({
|
|
220
|
+
id: memberCredentials.pubkey,
|
|
221
|
+
name: memberName,
|
|
222
|
+
});
|
|
223
|
+
send({ version, publisher, message: "TrustchainShareCredential", payload });
|
|
224
|
+
}
|
|
225
|
+
break;
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
yield commonSwitch({
|
|
229
|
+
data,
|
|
230
|
+
cipher,
|
|
231
|
+
addMember,
|
|
232
|
+
send,
|
|
233
|
+
publisher,
|
|
234
|
+
resolve,
|
|
235
|
+
memberCredentials,
|
|
236
|
+
memberName,
|
|
237
|
+
reject,
|
|
238
|
+
ws,
|
|
239
|
+
setFinished,
|
|
240
|
+
initialTrustchainId,
|
|
241
|
+
});
|
|
242
|
+
}
|
|
243
|
+
catch (e) {
|
|
244
|
+
console.error("socket error", e);
|
|
245
|
+
ws.close();
|
|
246
|
+
reject(e);
|
|
247
|
+
}
|
|
248
|
+
}));
|
|
249
|
+
ws.addEventListener("error", reject);
|
|
250
|
+
ws.addEventListener("open", () => {
|
|
251
|
+
const payload = { ephemeral_public_key: crypto.to_hex(ephemeralKey.publicKey) };
|
|
252
|
+
send({ version, publisher, message: "InitiateHandshake", payload });
|
|
253
|
+
});
|
|
254
|
+
});
|
|
255
|
+
});
|
|
256
|
+
}
|
|
257
|
+
function randomDigits(count) {
|
|
258
|
+
const bytes = crypto.randomBytes(count);
|
|
259
|
+
let digits = "";
|
|
260
|
+
for (let i = 0; i < count; i++) {
|
|
261
|
+
digits += (bytes[i] % 10).toString();
|
|
262
|
+
}
|
|
263
|
+
return digits;
|
|
264
|
+
}
|
|
265
|
+
function parseMessage(e) {
|
|
266
|
+
const message = JSON.parse(e.toString());
|
|
267
|
+
if (!message || typeof message !== "object") {
|
|
268
|
+
throw new Error("invalid message");
|
|
269
|
+
}
|
|
270
|
+
if (message.version !== 1) {
|
|
271
|
+
throw new Error("invalid version");
|
|
272
|
+
}
|
|
273
|
+
if (typeof message.publisher !== "string") {
|
|
274
|
+
throw new Error("invalid publisher");
|
|
275
|
+
}
|
|
276
|
+
if (typeof message.message !== "string") {
|
|
277
|
+
throw new Error("invalid message");
|
|
278
|
+
}
|
|
279
|
+
if (typeof message.payload !== "object") {
|
|
280
|
+
throw new Error("invalid payload");
|
|
281
|
+
}
|
|
282
|
+
return message;
|
|
283
|
+
}
|
|
284
|
+
function fromErrorMessage(payload) {
|
|
285
|
+
if (payload.type === "HANDSHAKE_COMPLETION_FAILED") {
|
|
286
|
+
throw new InvalidDigitsError(payload.message);
|
|
287
|
+
}
|
|
288
|
+
if (payload.type === "UNEXPECTED_SHARE_CREDENTIAL") {
|
|
289
|
+
throw new NoTrustchainInitialized(payload.message);
|
|
290
|
+
}
|
|
291
|
+
if (payload.type === "UNEXPECTED_REQUEST_CREDENTIAL") {
|
|
292
|
+
throw new TrustchainAlreadyInitialized(payload.message);
|
|
293
|
+
}
|
|
294
|
+
const error = new Error(payload.message);
|
|
295
|
+
error.name = "TrustchainQRCode-" + payload.type;
|
|
296
|
+
return error;
|
|
297
|
+
}
|
|
298
|
+
function isFromOldAccountsImport(scannedUrl) {
|
|
299
|
+
return !!scannedUrl.match(/^[A-Za-z0-9+/=]*$/);
|
|
300
|
+
}
|
|
301
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/qrcode/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.test.d.ts","sourceRoot":"","sources":["../../src/qrcode/index.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
import { createQRCodeHostInstance, createQRCodeCandidateInstance } from ".";
|
|
11
|
+
import WebSocket from "ws";
|
|
12
|
+
import { convertKeyPairToLiveCredentials } from "../sdk";
|
|
13
|
+
import { crypto } from "@ledgerhq/hw-ledger-key-ring-protocol";
|
|
14
|
+
import { ScannedInvalidQrCode, ScannedOldImportQrCode } from "../errors";
|
|
15
|
+
describe("Trustchain QR Code", () => {
|
|
16
|
+
let server;
|
|
17
|
+
let a;
|
|
18
|
+
let b;
|
|
19
|
+
beforeAll(() => {
|
|
20
|
+
server = new WebSocket.Server({ port: 1234 });
|
|
21
|
+
server.on("connection", ws => {
|
|
22
|
+
if (!a) {
|
|
23
|
+
a = ws;
|
|
24
|
+
}
|
|
25
|
+
else if (!b) {
|
|
26
|
+
b = ws;
|
|
27
|
+
}
|
|
28
|
+
ws.on("message", message => {
|
|
29
|
+
if (ws === a && b) {
|
|
30
|
+
b.send(message);
|
|
31
|
+
}
|
|
32
|
+
else if (ws === b && a) {
|
|
33
|
+
a.send(message);
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
afterAll(() => {
|
|
39
|
+
server.close();
|
|
40
|
+
});
|
|
41
|
+
test("digits matching scenario", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
42
|
+
const onDisplayDigits = jest.fn();
|
|
43
|
+
const trustchain = {
|
|
44
|
+
rootId: "test-root-id",
|
|
45
|
+
walletSyncEncryptionKey: "test-wallet-sync-encryption-key",
|
|
46
|
+
applicationPath: "m/0'/16'/0'",
|
|
47
|
+
};
|
|
48
|
+
const addMember = jest.fn(() => Promise.resolve(trustchain));
|
|
49
|
+
const memberCredentials = convertKeyPairToLiveCredentials(yield crypto.randomKeypair());
|
|
50
|
+
const memberName = "foo";
|
|
51
|
+
let scannedUrlResolve;
|
|
52
|
+
const scannedUrlPromise = new Promise(resolve => {
|
|
53
|
+
scannedUrlResolve = resolve;
|
|
54
|
+
});
|
|
55
|
+
const onDisplayQRCode = (url) => {
|
|
56
|
+
scannedUrlResolve(url);
|
|
57
|
+
};
|
|
58
|
+
const onRequestQRCodeInput = jest.fn((config, callback) => callback(onDisplayDigits.mock.calls[0][0]));
|
|
59
|
+
const hostP = createQRCodeHostInstance({
|
|
60
|
+
trustchainApiBaseUrl: "ws://localhost:1234",
|
|
61
|
+
onDisplayQRCode,
|
|
62
|
+
onDisplayDigits,
|
|
63
|
+
addMember,
|
|
64
|
+
memberCredentials,
|
|
65
|
+
memberName,
|
|
66
|
+
initialTrustchainId: trustchain.rootId,
|
|
67
|
+
});
|
|
68
|
+
const scannedUrl = yield scannedUrlPromise;
|
|
69
|
+
const candidateP = createQRCodeCandidateInstance({
|
|
70
|
+
memberCredentials,
|
|
71
|
+
memberName,
|
|
72
|
+
initialTrustchainId: undefined,
|
|
73
|
+
addMember,
|
|
74
|
+
scannedUrl,
|
|
75
|
+
onRequestQRCodeInput,
|
|
76
|
+
});
|
|
77
|
+
const [_, res] = yield Promise.all([hostP, candidateP]);
|
|
78
|
+
expect(onDisplayDigits).toHaveBeenCalledWith(expect.any(String));
|
|
79
|
+
expect(addMember).toHaveBeenCalled();
|
|
80
|
+
expect(onRequestQRCodeInput).toHaveBeenCalledWith({ digits: 3, connected: false }, expect.any(Function));
|
|
81
|
+
expect(res).toEqual(trustchain);
|
|
82
|
+
}));
|
|
83
|
+
test("invalid qr code scanned", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
84
|
+
const trustchain = {
|
|
85
|
+
rootId: "test-root-id",
|
|
86
|
+
walletSyncEncryptionKey: "test-wallet-sync-encryption-key",
|
|
87
|
+
applicationPath: "m/0'/16'/0'",
|
|
88
|
+
};
|
|
89
|
+
const addMember = jest.fn(() => Promise.resolve(trustchain));
|
|
90
|
+
const memberCredentials = convertKeyPairToLiveCredentials(yield crypto.randomKeypair());
|
|
91
|
+
const memberName = "foo";
|
|
92
|
+
const onRequestQRCodeInput = jest.fn();
|
|
93
|
+
const scannedUrl = "https://example.com";
|
|
94
|
+
const candidateP = createQRCodeCandidateInstance({
|
|
95
|
+
memberCredentials,
|
|
96
|
+
memberName,
|
|
97
|
+
initialTrustchainId: undefined,
|
|
98
|
+
addMember,
|
|
99
|
+
scannedUrl,
|
|
100
|
+
onRequestQRCodeInput,
|
|
101
|
+
});
|
|
102
|
+
yield expect(candidateP).rejects.toThrow(new ScannedInvalidQrCode());
|
|
103
|
+
}));
|
|
104
|
+
test("old accounts export qr code scanned", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
105
|
+
const trustchain = {
|
|
106
|
+
rootId: "test-root-id",
|
|
107
|
+
walletSyncEncryptionKey: "test-wallet-sync-encryption-key",
|
|
108
|
+
applicationPath: "m/0'/16'/0'",
|
|
109
|
+
};
|
|
110
|
+
const addMember = jest.fn(() => Promise.resolve(trustchain));
|
|
111
|
+
const memberCredentials = convertKeyPairToLiveCredentials(yield crypto.randomKeypair());
|
|
112
|
+
const memberName = "foo";
|
|
113
|
+
const onRequestQRCodeInput = jest.fn();
|
|
114
|
+
const scannedUrl = "ZAADAAIAAAAEd2JXMpuoYdzvkNzFTlmQLPcGf2LSjDOgqaB3nQoZqlimcCX6HNkescWKyT1DCGuwO7IesD7oYg+fdZPkiIfFL3V9swfZRePkaNN09IjXsWLsim9hK/qi/RC1/ofX3hYNKUxUAgYVVG82WKXIk47siWfUlRZsCYSAARQ6ASpUgidPjMHaOMK6w53wTZplwo7Zjv1HrIyKwr3Ci8OmrFye5g==";
|
|
115
|
+
const candidateP = createQRCodeCandidateInstance({
|
|
116
|
+
memberCredentials,
|
|
117
|
+
memberName,
|
|
118
|
+
initialTrustchainId: undefined,
|
|
119
|
+
addMember,
|
|
120
|
+
scannedUrl,
|
|
121
|
+
onRequestQRCodeInput,
|
|
122
|
+
});
|
|
123
|
+
yield expect(candidateP).rejects.toThrow(new ScannedOldImportQrCode());
|
|
124
|
+
}));
|
|
125
|
+
});
|
|
126
|
+
//# sourceMappingURL=index.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.test.js","sourceRoot":"","sources":["../../src/qrcode/index.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { Trustchain } from "../types";
|
|
2
|
+
export type Encrypted<T> = {
|
|
3
|
+
encrypted: string;
|
|
4
|
+
};
|
|
5
|
+
export type Message = {
|
|
6
|
+
version: number;
|
|
7
|
+
publisher: string;
|
|
8
|
+
message: "InitiateHandshake";
|
|
9
|
+
payload: {
|
|
10
|
+
ephemeral_public_key: string;
|
|
11
|
+
};
|
|
12
|
+
} | {
|
|
13
|
+
version: number;
|
|
14
|
+
publisher: string;
|
|
15
|
+
message: "Failure";
|
|
16
|
+
payload: {
|
|
17
|
+
message: string;
|
|
18
|
+
type: string;
|
|
19
|
+
};
|
|
20
|
+
} | {
|
|
21
|
+
version: number;
|
|
22
|
+
publisher: string;
|
|
23
|
+
message: "HandshakeChallenge";
|
|
24
|
+
payload: Encrypted<{
|
|
25
|
+
digits: number;
|
|
26
|
+
connected: boolean;
|
|
27
|
+
}>;
|
|
28
|
+
} | {
|
|
29
|
+
version: number;
|
|
30
|
+
publisher: string;
|
|
31
|
+
message: "CompleteHandshakeChallenge";
|
|
32
|
+
payload: Encrypted<{
|
|
33
|
+
digits: string;
|
|
34
|
+
}>;
|
|
35
|
+
} | {
|
|
36
|
+
version: number;
|
|
37
|
+
publisher: string;
|
|
38
|
+
message: "HandshakeCompletionSucceeded";
|
|
39
|
+
payload: Encrypted<Record<string, never>>;
|
|
40
|
+
} | {
|
|
41
|
+
version: number;
|
|
42
|
+
publisher: string;
|
|
43
|
+
message: "TrustchainRequestCredential";
|
|
44
|
+
payload: Encrypted<Record<string, never>>;
|
|
45
|
+
} | {
|
|
46
|
+
version: number;
|
|
47
|
+
publisher: string;
|
|
48
|
+
message: "TrustchainShareCredential";
|
|
49
|
+
payload: Encrypted<{
|
|
50
|
+
id: string;
|
|
51
|
+
name: string;
|
|
52
|
+
}>;
|
|
53
|
+
} | {
|
|
54
|
+
version: number;
|
|
55
|
+
publisher: string;
|
|
56
|
+
message: "TrustchainAddedMember";
|
|
57
|
+
payload: Encrypted<{
|
|
58
|
+
trustchain: Trustchain;
|
|
59
|
+
}>;
|
|
60
|
+
};
|
|
61
|
+
export type DecryptedPayload<M> = M extends {
|
|
62
|
+
payload: Encrypted<infer T>;
|
|
63
|
+
} ? T : M extends {
|
|
64
|
+
payload: infer T;
|
|
65
|
+
} ? T : never;
|
|
66
|
+
export type ExtractEncryptedPayloads<T> = T extends {
|
|
67
|
+
payload: Encrypted<infer P>;
|
|
68
|
+
} ? P : never;
|
|
69
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/qrcode/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAGtC,MAAM,MAAM,SAAS,CAAC,CAAC,IAAI;IACzB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AACF,MAAM,MAAM,OAAO,GACf;IACE,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,mBAAmB,CAAC;IAC7B,OAAO,EAAE;QAAE,oBAAoB,EAAE,MAAM,CAAA;KAAE,CAAC;CAC3C,GACD;IACE,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,SAAS,CAAC;IACnB,OAAO,EAAE;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;CAC5C,GACD;IACE,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,oBAAoB,CAAC;IAC9B,OAAO,EAAE,SAAS,CAAC;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,OAAO,CAAA;KAAE,CAAC,CAAC;CAC5D,GACD;IACE,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,4BAA4B,CAAC;IACtC,OAAO,EAAE,SAAS,CAAC;QAAE,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CACxC,GACD;IACE,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,8BAA8B,CAAC;IACxC,OAAO,EAAE,SAAS,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC;CAC3C,GACD;IACE,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,6BAA6B,CAAC;IACvC,OAAO,EAAE,SAAS,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC;CAC3C,GACD;IACE,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,2BAA2B,CAAC;IACrC,OAAO,EAAE,SAAS,CAAC;QAEjB,EAAE,EAAE,MAAM,CAAC;QAEX,IAAI,EAAE,MAAM,CAAC;KACd,CAAC,CAAC;CACJ,GACD;IACE,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,uBAAuB,CAAC;IACjC,OAAO,EAAE,SAAS,CAAC;QACjB,UAAU,EAAE,UAAU,CAAC;KACxB,CAAC,CAAC;CACJ,CAAC;AAEN,MAAM,MAAM,gBAAgB,CAAC,CAAC,IAAI,CAAC,SAAS;IAAE,OAAO,EAAE,SAAS,CAAC,MAAM,CAAC,CAAC,CAAA;CAAE,GACvE,CAAC,GACD,CAAC,SAAS;IAAE,OAAO,EAAE,MAAM,CAAC,CAAA;CAAE,GAC5B,CAAC,GACD,KAAK,CAAC;AAEZ,MAAM,MAAM,wBAAwB,CAAC,CAAC,IAAI,CAAC,SAAS;IAAE,OAAO,EAAE,SAAS,CAAC,MAAM,CAAC,CAAC,CAAA;CAAE,GAAG,CAAC,GAAG,KAAK,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/qrcode/types.ts"],"names":[],"mappings":""}
|
package/lib-es/sdk.d.ts
ADDED
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { JWT, MemberCredentials, TrustchainSDKContext, Trustchain, TrustchainMember, TrustchainSDK, TrustchainDeviceCallbacks, AuthCachePolicy, TrustchainResult, TrustchainLifecycle, GetOrCreateTrustchainCallbacks } from "./types";
|
|
2
|
+
import { KeyPair as CryptoKeyPair } from "@ledgerhq/hw-ledger-key-ring-protocol/Crypto";
|
|
3
|
+
import { HWDeviceProvider } from "./HWDeviceProvider";
|
|
4
|
+
export declare class SDK implements TrustchainSDK {
|
|
5
|
+
private context;
|
|
6
|
+
private hwDeviceProvider;
|
|
7
|
+
private lifecycle?;
|
|
8
|
+
private api;
|
|
9
|
+
constructor(context: TrustchainSDKContext, hwDeviceProvider: HWDeviceProvider, lifecyle?: TrustchainLifecycle);
|
|
10
|
+
private jwt;
|
|
11
|
+
private jwtHash;
|
|
12
|
+
withAuth<T>(trustchain: Trustchain, memberCredentials: MemberCredentials, job: (jwt: JWT) => Promise<T>, policy?: AuthCachePolicy, ignorePermissionsChecks?: boolean): Promise<T>;
|
|
13
|
+
initMemberCredentials(): Promise<MemberCredentials>;
|
|
14
|
+
getOrCreateTrustchain(deviceId: string, memberCredentials: MemberCredentials, callbacks?: GetOrCreateTrustchainCallbacks, topic?: Uint8Array, currentTrustchain?: Trustchain): Promise<TrustchainResult>;
|
|
15
|
+
restoreTrustchain(trustchain: Trustchain, memberCredentials: MemberCredentials): Promise<Trustchain>;
|
|
16
|
+
getMembers(trustchain: Trustchain, memberCredentials: MemberCredentials): Promise<TrustchainMember[]>;
|
|
17
|
+
removeMember(deviceId: string, trustchain: Trustchain, memberCredentials: MemberCredentials, member: TrustchainMember, callbacks?: TrustchainDeviceCallbacks): Promise<Trustchain>;
|
|
18
|
+
addMember(trustchain: Trustchain, memberCredentials: MemberCredentials, member: TrustchainMember): Promise<void>;
|
|
19
|
+
invalidateJwt(): void;
|
|
20
|
+
destroyTrustchain(trustchain: Trustchain, memberCredentials: MemberCredentials): Promise<void>;
|
|
21
|
+
encryptUserData(trustchain: Trustchain, input: Uint8Array): Promise<Uint8Array>;
|
|
22
|
+
decryptUserData(trustchain: Trustchain, data: Uint8Array): Promise<Uint8Array>;
|
|
23
|
+
private fetchTrustchain;
|
|
24
|
+
private fetchTrustchainAndResolve;
|
|
25
|
+
private auth;
|
|
26
|
+
private pushMember;
|
|
27
|
+
private closeStream;
|
|
28
|
+
}
|
|
29
|
+
export declare function convertKeyPairToLiveCredentials(keyPair: CryptoKeyPair): MemberCredentials;
|
|
30
|
+
export declare function convertLiveCredentialsToKeyPair(memberCredentials: MemberCredentials): CryptoKeyPair;
|
|
31
|
+
//# sourceMappingURL=sdk.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sdk.d.ts","sourceRoot":"","sources":["../src/sdk.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,GAAG,EACH,iBAAiB,EACjB,oBAAoB,EACpB,UAAU,EACV,gBAAgB,EAChB,aAAa,EACb,yBAAyB,EACzB,eAAe,EACf,gBAAgB,EAEhB,mBAAmB,EACnB,8BAA8B,EAC/B,MAAM,SAAS,CAAC;AAYjB,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,8CAA8C,CAAC;AAUxF,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAMtD,qBAAa,GAAI,YAAW,aAAa;IACvC,OAAO,CAAC,OAAO,CAAuB;IACtC,OAAO,CAAC,gBAAgB,CAAmB;IAC3C,OAAO,CAAC,SAAS,CAAC,CAAsB;IACxC,OAAO,CAAC,GAAG,CAA4B;gBAGrC,OAAO,EAAE,oBAAoB,EAC7B,gBAAgB,EAAE,gBAAgB,EAClC,QAAQ,CAAC,EAAE,mBAAmB;IAQhC,OAAO,CAAC,GAAG,CAA8B;IACzC,OAAO,CAAC,OAAO,CAAM;IACrB,QAAQ,CAAC,CAAC,EACR,UAAU,EAAE,UAAU,EACtB,iBAAiB,EAAE,iBAAiB,EACpC,GAAG,EAAE,CAAC,GAAG,EAAE,GAAG,KAAK,OAAO,CAAC,CAAC,CAAC,EAC7B,MAAM,CAAC,EAAE,eAAe,EACxB,uBAAuB,CAAC,EAAE,OAAO,GAChC,OAAO,CAAC,CAAC,CAAC;IA8BP,qBAAqB,IAAI,OAAO,CAAC,iBAAiB,CAAC;IAKnD,qBAAqB,CACzB,QAAQ,EAAE,MAAM,EAChB,iBAAiB,EAAE,iBAAiB,EACpC,SAAS,CAAC,EAAE,8BAA8B,EAC1C,KAAK,CAAC,EAAE,UAAU,EAClB,iBAAiB,CAAC,EAAE,UAAU,GAC7B,OAAO,CAAC,gBAAgB,CAAC;IAsFtB,iBAAiB,CACrB,UAAU,EAAE,UAAU,EACtB,iBAAiB,EAAE,iBAAiB,GACnC,OAAO,CAAC,UAAU,CAAC;IAqBhB,UAAU,CACd,UAAU,EAAE,UAAU,EACtB,iBAAiB,EAAE,iBAAiB,GACnC,OAAO,CAAC,gBAAgB,EAAE,CAAC;IAWxB,YAAY,CAChB,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,UAAU,EACtB,iBAAiB,EAAE,iBAAiB,EACpC,MAAM,EAAE,gBAAgB,EACxB,SAAS,CAAC,EAAE,yBAAyB,GACpC,OAAO,CAAC,UAAU,CAAC;IAqFhB,SAAS,CACb,UAAU,EAAE,UAAU,EACtB,iBAAiB,EAAE,iBAAiB,EACpC,MAAM,EAAE,gBAAgB,GACvB,OAAO,CAAC,IAAI,CAAC;IAiBhB,aAAa;IAKP,iBAAiB,CACrB,UAAU,EAAE,UAAU,EACtB,iBAAiB,EAAE,iBAAiB,GACnC,OAAO,CAAC,IAAI,CAAC;IAOV,eAAe,CAAC,UAAU,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;IAM/E,eAAe,CAAC,UAAU,EAAE,UAAU,EAAE,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;YAMtE,eAAe;YAMf,yBAAyB;YASzB,IAAI;YA4BJ,UAAU;YAoCV,WAAW;CAkB1B;AAED,wBAAgB,+BAA+B,CAAC,OAAO,EAAE,aAAa,GAAG,iBAAiB,CAKzF;AAED,wBAAgB,+BAA+B,CAC7C,iBAAiB,EAAE,iBAAiB,GACnC,aAAa,CAKf"}
|