@inco/js 0.1.35 → 0.1.37
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/README.md +20 -0
- package/dist/binary.js +32 -47
- package/dist/chain.js +7 -11
- package/dist/encryption/encryption.js +54 -62
- package/dist/encryption/index.cjs +24706 -0
- package/dist/encryption/index.js +2 -18
- package/dist/encryption/index.mjs +25787 -0
- package/dist/fhevm/fhe-environment.js +6 -9
- package/dist/fhevm/fhevm.js +34 -40
- package/dist/fhevm/index.cjs +87 -0
- package/dist/fhevm/index.js +2 -18
- package/dist/fhevm/index.mjs +90 -0
- package/dist/fhevm/reencrypt.js +33 -37
- package/dist/fhevm/tfhe.js +79 -87
- package/dist/fhevm/types.js +13 -16
- package/dist/generated/abis/addTwo.js +2 -5
- package/dist/generated/abis/inco-fhevm.js +47 -50
- package/dist/generated/abis/index.cjs +12493 -0
- package/dist/generated/abis/index.js +3 -19
- package/dist/generated/abis/index.mjs +12496 -0
- package/dist/generated/abis/lightning.d.ts +1361 -115
- package/dist/generated/abis/lightning.js +1043 -140
- package/dist/generated/es/cosmos/ics23/v1/proofs_pb.js +22 -25
- package/dist/generated/es/cosmos/msg/v1/msg_pb.js +6 -9
- package/dist/generated/es/cosmos_proto/cosmos_pb.js +18 -21
- package/dist/generated/es/google/api/annotations_pb.js +6 -9
- package/dist/generated/es/google/api/http_pb.js +6 -9
- package/dist/generated/es/inco/fhe/v1/events_pb.js +7 -10
- package/dist/generated/es/inco/fhe/v1/genesis_pb.js +12 -15
- package/dist/generated/es/inco/fhe/v1/query_pb.js +25 -28
- package/dist/generated/es/inco/fhe/v1/tx_pb.js +25 -28
- package/dist/generated/es/inco/fhe/v1/types_pb.js +19 -22
- package/dist/generated/es/inco/kms/lite/v1/kms_service_pb.js +11 -14
- package/dist/generated/es/inco/kms/lite/v1/types_pb.js +10 -13
- package/dist/generated/es/inco/preflight/v1/genesis_pb.js +6 -9
- package/dist/generated/es/inco/preflight/v1/query_pb.js +11 -14
- package/dist/generated/es/inco/preflight/v1/tx_pb.js +13 -16
- package/dist/generated/es/inco/preflight/v1/types_pb.js +8 -11
- package/dist/generated/es/kms/base_pb.js +35 -38
- package/dist/generated/es/sf/ethereum/type/v2/type_pb.js +43 -46
- package/dist/generated/fhe-environments.js +2 -5
- package/dist/generated/lightning.d.ts +21 -0
- package/dist/generated/lightning.js +24 -5
- package/dist/generated/local-node.js +2 -5
- package/dist/generated/ts/amino/amino.js +2 -5
- package/dist/generated/ts/cometbft/abci/v1/types.js +547 -563
- package/dist/generated/ts/cometbft/crypto/v1/keys.js +7 -10
- package/dist/generated/ts/cometbft/crypto/v1/proof.js +33 -36
- package/dist/generated/ts/cometbft/types/v1/params.js +95 -98
- package/dist/generated/ts/cometbft/types/v1/validator.js +40 -45
- package/dist/generated/ts/cosmos/app/v1alpha1/module.js +25 -28
- package/dist/generated/ts/cosmos/msg/v1/msg.js +2 -5
- package/dist/generated/ts/cosmos_proto/cosmos.js +15 -20
- package/dist/generated/ts/gogoproto/gogo.js +2 -5
- package/dist/generated/ts/google/api/annotations.js +2 -5
- package/dist/generated/ts/google/api/http.js +30 -33
- package/dist/generated/ts/google/protobuf/descriptor.js +468 -506
- package/dist/generated/ts/google/protobuf/duration.js +7 -10
- package/dist/generated/ts/google/protobuf/timestamp.js +7 -10
- package/dist/generated/ts/google/protobuf/wrappers.js +39 -42
- package/dist/generated/ts/inco/abci/v1/types.js +13 -16
- package/dist/generated/ts/inco/fhe/module/v1/module.js +7 -10
- package/dist/generated/ts/inco/fhe/v1/events.js +32 -35
- package/dist/generated/ts/inco/fhe/v1/genesis.js +127 -130
- package/dist/generated/ts/inco/fhe/v1/query.js +160 -163
- package/dist/generated/ts/inco/fhe/v1/tx.js +150 -153
- package/dist/generated/ts/inco/fhe/v1/types.js +70 -75
- package/dist/generated/ts/inco/originchain/module/v1/module.js +7 -10
- package/dist/generated/ts/inco/originchain/v1/abci.js +34 -37
- package/dist/generated/ts/inco/originchain/v1/events.js +11 -14
- package/dist/generated/ts/inco/originchain/v1/genesis.js +13 -16
- package/dist/generated/ts/inco/originchain/v1/query.js +41 -44
- package/dist/generated/ts/inco/originchain/v1/tx.js +24 -27
- package/dist/generated/ts/inco/originchain/v1/types.js +11 -14
- package/dist/generated/ts/inco/preflight/module/v1/module.js +7 -10
- package/dist/generated/ts/inco/preflight/v1/genesis.js +27 -30
- package/dist/generated/ts/inco/preflight/v1/query.js +41 -44
- package/dist/generated/ts/inco/preflight/v1/tx.js +53 -56
- package/dist/generated/ts/inco/preflight/v1/types.js +38 -41
- package/dist/handle.js +26 -33
- package/dist/index.cjs +24883 -0
- package/dist/index.js +6 -22
- package/dist/index.mjs +25964 -0
- package/dist/l1/client.js +19 -23
- package/dist/l1/index.js +3 -19
- package/dist/l1/preflight.js +13 -16
- package/dist/lite/deployments.js +9 -13
- package/dist/lite/ecies.js +37 -48
- package/dist/lite/hadu.js +21 -26
- package/dist/lite/index.cjs +52789 -0
- package/dist/lite/index.js +7 -23
- package/dist/lite/index.mjs +71691 -0
- package/dist/lite/lightning.js +31 -35
- package/dist/lite/reencrypt.d.ts +4 -4
- package/dist/lite/reencrypt.js +33 -44
- package/dist/local/index.cjs +24479 -0
- package/dist/local/index.js +2 -18
- package/dist/local/index.mjs +42864 -0
- package/dist/local/local-node.js +21 -25
- package/dist/reencryption/eip712.js +18 -21
- package/dist/reencryption/index.cjs +24681 -0
- package/dist/reencryption/index.js +3 -19
- package/dist/reencryption/index.mjs +24684 -0
- package/dist/reencryption/types.d.ts +6 -1
- package/dist/reencryption/types.js +1 -2
- package/dist/schema.js +6 -10
- package/dist/viem.js +7 -11
- package/package.json +1 -1
package/dist/l1/client.js
CHANGED
@@ -1,15 +1,11 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
const fhe = require("../generated/es/inco/fhe/v1/query_pb");
|
10
|
-
const preflight = require("../generated/es/inco/preflight/v1/query_pb");
|
11
|
-
const tx_1 = require("../generated/ts/inco/fhe/v1/tx");
|
12
|
-
const tx_2 = require("../generated/ts/inco/preflight/v1/tx");
|
1
|
+
import { createClient } from '@connectrpc/connect';
|
2
|
+
import { createGrpcTransport } from '@connectrpc/connect-node';
|
3
|
+
import { DirectSecp256k1HdWallet, Registry } from '@cosmjs/proto-signing';
|
4
|
+
import { defaultRegistryTypes as defaultStargateTypes, SigningStargateClient, } from '@cosmjs/stargate';
|
5
|
+
import * as fhe from '../generated/es/inco/fhe/v1/query_pb';
|
6
|
+
import * as preflight from '../generated/es/inco/preflight/v1/query_pb';
|
7
|
+
import { MsgAddCovalidator, MsgAddFheEnv } from '../generated/ts/inco/fhe/v1/tx';
|
8
|
+
import { MsgRegisterInput } from '../generated/ts/inco/preflight/v1/tx';
|
13
9
|
// We could have extracted these strings from types inside
|
14
10
|
// ../generated/es/fhe/v1/tx_pb, but it seems more readable to hardcode
|
15
11
|
// them here.
|
@@ -23,9 +19,9 @@ const msgAddFheEnvTypeUrl = '/inco.fhe.v1.MsgAddFheEnv';
|
|
23
19
|
// If we want to support more messages for strong TS typings, we need to add
|
24
20
|
// them here.
|
25
21
|
const supportedMsgs = {
|
26
|
-
[msgRegisterInputTypeUrl]:
|
27
|
-
[msgAddCovalidatorTypeUrl]:
|
28
|
-
[msgAddFheEnvTypeUrl]:
|
22
|
+
[msgRegisterInputTypeUrl]: MsgRegisterInput,
|
23
|
+
[msgAddCovalidatorTypeUrl]: MsgAddCovalidator,
|
24
|
+
[msgAddFheEnvTypeUrl]: MsgAddFheEnv,
|
29
25
|
};
|
30
26
|
// The list of supported queries on the Inco L1.
|
31
27
|
//
|
@@ -35,22 +31,22 @@ const supportedQueries = {
|
|
35
31
|
fhe,
|
36
32
|
preflight,
|
37
33
|
};
|
38
|
-
async function createL1Wallet(mnemonic) {
|
39
|
-
return await
|
34
|
+
export async function createL1Wallet(mnemonic) {
|
35
|
+
return await DirectSecp256k1HdWallet.fromMnemonic(mnemonic, { prefix: 'inco' });
|
40
36
|
}
|
41
37
|
// Creates a Cosmos L1 client using CosmJS.
|
42
|
-
async function createL1Client({ cometRpcEndpoint, grpcEndpoint, wallet, waitTimeForTxInclusion = 10_000, }) {
|
38
|
+
export async function createL1Client({ cometRpcEndpoint, grpcEndpoint, wallet, waitTimeForTxInclusion = 10_000, }) {
|
43
39
|
// Manual registry creation is required to register custom Msg types.
|
44
|
-
const registry = new
|
40
|
+
const registry = new Registry(defaultStargateTypes);
|
45
41
|
Object.entries(supportedMsgs).forEach(([typeUrl, message]) => {
|
46
42
|
// @ts-ignore TODO: Fix this typing issue. This was introcued in:
|
47
43
|
// https://github.com/Inco-fhevm/inco-monorepo/pull/251
|
48
44
|
registry.register(typeUrl, message);
|
49
45
|
});
|
50
46
|
// Create one shared gRPC transport for all queries.
|
51
|
-
const transport =
|
52
|
-
const query = Object.fromEntries(Object.entries(supportedQueries).map(([k, v]) => [k,
|
53
|
-
const signingClient = await
|
47
|
+
const transport = createGrpcTransport({ baseUrl: grpcEndpoint });
|
48
|
+
const query = Object.fromEntries(Object.entries(supportedQueries).map(([k, v]) => [k, createClient(v.Query, transport)]));
|
49
|
+
const signingClient = await SigningStargateClient.connectWithSigner(cometRpcEndpoint, wallet, {
|
54
50
|
registry,
|
55
51
|
});
|
56
52
|
// We currently assume that the Inco chain has 0 fees and hardcode the default gas limit.
|
@@ -94,4 +90,4 @@ async function createL1Client({ cometRpcEndpoint, grpcEndpoint, wallet, waitTime
|
|
94
90
|
},
|
95
91
|
};
|
96
92
|
}
|
97
|
-
//# sourceMappingURL=data:application/json;base64,
|
93
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2wxL2NsaWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQVUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDM0QsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDL0QsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFFBQVEsRUFBc0IsTUFBTSx1QkFBdUIsQ0FBQztBQUM5RixPQUFPLEVBQ0wsb0JBQW9CLElBQUksb0JBQW9CLEVBRTVDLHFCQUFxQixHQUV0QixNQUFNLGtCQUFrQixDQUFDO0FBQzFCLE9BQU8sS0FBSyxHQUFHLE1BQU0sc0NBQXNDLENBQUM7QUFDNUQsT0FBTyxLQUFLLFNBQVMsTUFBTSw0Q0FBNEMsQ0FBQztBQUN4RSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsWUFBWSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDakYsT0FBTyxFQUFjLGdCQUFnQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFlcEYsMERBQTBEO0FBQzFELHVFQUF1RTtBQUN2RSxhQUFhO0FBQ2IsTUFBTSx1QkFBdUIsR0FBRyxxQ0FBcUMsQ0FBQztBQUN0RSxNQUFNLHdCQUF3QixHQUFHLGdDQUFnQyxDQUFDO0FBQ2xFLE1BQU0sbUJBQW1CLEdBQUcsMkJBQTJCLENBQUM7QUFFeEQsNEVBQTRFO0FBQzVFLHdFQUF3RTtBQUN4RSxzQkFBc0I7QUFDdEIsRUFBRTtBQUNGLDRFQUE0RTtBQUM1RSxhQUFhO0FBQ2IsTUFBTSxhQUFhLEdBQUc7SUFDcEIsQ0FBQyx1QkFBdUIsQ0FBQyxFQUFFLGdCQUFnQjtJQUMzQyxDQUFDLHdCQUF3QixDQUFDLEVBQUUsaUJBQWlCO0lBQzdDLENBQUMsbUJBQW1CLENBQUMsRUFBRSxZQUFZO0NBQ3BDLENBQUM7QUFNRixnREFBZ0Q7QUFDaEQsRUFBRTtBQUNGLDZFQUE2RTtBQUM3RSx5QkFBeUI7QUFDekIs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
|
package/dist/l1/index.js
CHANGED
@@ -1,19 +1,3 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
-
}
|
8
|
-
Object.defineProperty(o, k2, desc);
|
9
|
-
}) : (function(o, m, k, k2) {
|
10
|
-
if (k2 === undefined) k2 = k;
|
11
|
-
o[k2] = m[k];
|
12
|
-
}));
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
15
|
-
};
|
16
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
17
|
-
__exportStar(require("./client"), exports);
|
18
|
-
__exportStar(require("./preflight"), exports);
|
19
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbDEvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDJDQUF5QjtBQUN6Qiw4Q0FBNEIifQ==
|
1
|
+
export * from './client';
|
2
|
+
export * from './preflight';
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbDEvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxhQUFhLENBQUMifQ==
|
package/dist/l1/preflight.js
CHANGED
@@ -1,20 +1,17 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
const handle_1 = require("../handle");
|
8
|
-
const schema_1 = require("../schema");
|
9
|
-
const client_1 = require("./client");
|
1
|
+
import { Schema } from 'effect';
|
2
|
+
import { Bytes32, bytesFromHexString } from '../binary';
|
3
|
+
import { MsgRegisterInput } from '../generated/ts/inco/preflight/v1/tx';
|
4
|
+
import { computeHandle } from '../handle';
|
5
|
+
import { parse } from '../schema';
|
6
|
+
import { createL1Client } from './client';
|
10
7
|
// Do not export this value, only allow parsing of Handle to happen here
|
11
|
-
const Handle =
|
8
|
+
const Handle = Bytes32.pipe(Schema.brand('Handle'));
|
12
9
|
// Sends a preflight input to the Cosmos L1 chain using CosmJS.
|
13
|
-
async function cosmJSPreflight({ cometRpcEndpoint, grpcEndpoint, wallet, signerAddress, }) {
|
14
|
-
const l1Client = await
|
10
|
+
export async function cosmJSPreflight({ cometRpcEndpoint, grpcEndpoint, wallet, signerAddress, }) {
|
11
|
+
const l1Client = await createL1Client({ cometRpcEndpoint, wallet, grpcEndpoint });
|
15
12
|
return {
|
16
13
|
async send({ prehandle, ciphertext, context }) {
|
17
|
-
const msg =
|
14
|
+
const msg = MsgRegisterInput.create({
|
18
15
|
prehandle: Buffer.from(prehandle.replace(/^0x/, ''), 'hex'),
|
19
16
|
signer: signerAddress,
|
20
17
|
ciphertext: Buffer.from(ciphertext.value, 'hex'),
|
@@ -34,9 +31,9 @@ async function cosmJSPreflight({ cometRpcEndpoint, grpcEndpoint, wallet, signerA
|
|
34
31
|
// 2. The FheEnv must have been created in the on-chain registry. Only the
|
35
32
|
// council can add new FheEnvs to the registry.
|
36
33
|
const result = await l1Client.sendTx(signerAddress, '/inco.preflight.v1.MsgRegisterInput', msg);
|
37
|
-
const handle =
|
38
|
-
return { transactionHash: result.transactionHash, handle:
|
34
|
+
const handle = computeHandle({ prehandle: bytesFromHexString(prehandle), context });
|
35
|
+
return { transactionHash: result.transactionHash, handle: parse(Handle, handle) };
|
39
36
|
},
|
40
37
|
};
|
41
38
|
}
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJlZmxpZ2h0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2wxL3ByZWZsaWdodC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBQ2hDLE9BQU8sRUFBRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFFeEQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDeEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUMxQyxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQ2xDLE9BQU8sRUFBRSxjQUFjLEVBQXFCLE1BQU0sVUFBVSxDQUFDO0FBRTdELHdFQUF3RTtBQUN4RSxNQUFNLE1BQU0sR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztBQXNCcEQsK0RBQStEO0FBQy9ELE1BQU0sQ0FBQyxLQUFLLFVBQVUsZUFBZSxDQUFDLEVBQ3BDLGdCQUFnQixFQUNoQixZQUFZLEVBQ1osTUFBTSxFQUNOLGFBQWEsR0FDNEI7SUFDekMsTUFBTSxRQUFRLEdBQUcsTUFBTSxjQUFjLENBQUMsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLENBQUMsQ0FBQztJQUVsRixPQUFPO1FBQ0wsS0FBSyxDQUFDLElBQUksQ0FBQyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsT0FBTyxFQUFvQjtZQUM3RCxNQUFNLEdBQUcsR0FBRyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUM7Z0JBQ2xDLFNBQVMsRUFBRSxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxFQUFFLEtBQUssQ0FBQztnQkFDM0QsTUFBTSxFQUFFLGFBQWE7Z0JBQ3JCLFVBQVUsRUFBRSxNQUFNLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDO2dCQUNoRCxPQUFPLEVBQUU7b0JBQ1AsU0FBUyxFQUFFLE9BQU8sQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUM7b0JBQ2pELFlBQVksRUFBRSxPQUFPLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDO29CQUN4RCw0REFBNEQ7b0JBQzVELFFBQVEsRUFBRSxPQUFPLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDO29CQUMvQyxXQUFXLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxXQUFXO2lCQUMxQzthQUNGLENBQUMsQ0FBQztZQUVILDZFQUE2RTtZQUM3RSxFQUFFO1lBQ0Ysc0VBQXNFO1lBQ3RFLHlFQUF5RTtZQUN6RSw0REFBNEQ7WUFDNUQsMEVBQTBFO1lBQzFFLCtDQUErQztZQUMvQyxNQUFNLE1BQU0sR0FBRyxNQUFNLFFBQVEsQ0FBQyxNQUFNLENBQUMsYUFBYSxFQUFFLHFDQUFxQyxFQUFFLEdBQUcsQ0FBQyxDQUFDO1lBRWhHLE1BQU0sTUFBTSxHQUFHLGFBQWEsQ0FBQyxFQUFFLFNBQVMsRUFBRSxrQkFBa0IsQ0FBQyxTQUFTLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDO1lBQ3BGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxDQUFDLGVBQWUsRUFBRSxNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU0sRUFBRSxNQUFNLENBQUMsRUFBRSxDQUFDO1FBQ3BGLENBQUM7S0FDRixDQUFDO0FBQ0osQ0FBQyJ9
|
package/dist/lite/deployments.js
CHANGED
@@ -1,21 +1,17 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.getActiveLightningDeployment = getActiveLightningDeployment;
|
4
|
-
exports.getLightningDeployments = getLightningDeployments;
|
5
1
|
// Avoid inporting any other dependencies in this file to avoid serialisation issues downstream in infracto
|
6
|
-
|
7
|
-
|
8
|
-
function getActiveLightningDeployment(chain) {
|
9
|
-
const supportedChain =
|
10
|
-
const deployments =
|
2
|
+
import { getSupportedChain } from '../chain';
|
3
|
+
import { lightningDeployments } from '../generated/lightning';
|
4
|
+
export function getActiveLightningDeployment(chain) {
|
5
|
+
const supportedChain = getSupportedChain(chain);
|
6
|
+
const deployments = lightningDeployments.filter((d) => d.chainId === supportedChain.id);
|
11
7
|
if (!deployments?.length) {
|
12
8
|
throw new Error(`No deployments found for chain ${chain}`);
|
13
9
|
}
|
14
10
|
return deployments[0];
|
15
11
|
}
|
16
|
-
function getLightningDeployments(chainId) {
|
17
|
-
const supportedChain =
|
18
|
-
const deployments =
|
12
|
+
export function getLightningDeployments(chainId) {
|
13
|
+
const supportedChain = getSupportedChain(chainId);
|
14
|
+
const deployments = lightningDeployments.filter((d) => d.chainId === supportedChain.id);
|
19
15
|
return deployments ?? [];
|
20
16
|
}
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVwbG95bWVudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbGl0ZS9kZXBsb3ltZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSwyR0FBMkc7QUFDM0csT0FBTyxFQUFZLGlCQUFpQixFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQ3ZELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBTzlELE1BQU0sVUFBVSw0QkFBNEIsQ0FBQyxLQUFlO0lBQzFELE1BQU0sY0FBYyxHQUFHLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2hELE1BQU0sV0FBVyxHQUFHLG9CQUFvQixDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLE9BQU8sS0FBSyxjQUFjLENBQUMsRUFBRSxDQUFDLENBQUM7SUFDeEYsSUFBSSxDQUFDLFdBQVcsRUFBRSxNQUFNLEVBQUUsQ0FBQztRQUN6QixNQUFNLElBQUksS0FBSyxDQUFDLGtDQUFrQyxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFDRCxPQUFPLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUN4QixDQUFDO0FBRUQsTUFBTSxVQUFVLHVCQUF1QixDQUFDLE9BQWlCO0lBQ3ZELE1BQU0sY0FBYyxHQUFHLGlCQUFpQixDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2xELE1BQU0sV0FBVyxHQUFHLG9CQUFvQixDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLE9BQU8sS0FBSyxjQUFjLENBQUMsRUFBRSxDQUFDLENBQUM7SUFDeEYsT0FBTyxXQUFXLElBQUksRUFBRSxDQUFDO0FBQzNCLENBQUMifQ==
|
package/dist/lite/ecies.js
CHANGED
@@ -1,26 +1,15 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
exports.encrypt = encrypt;
|
9
|
-
exports.getEciesEncryptor = getEciesEncryptor;
|
10
|
-
exports.decrypt = decrypt;
|
11
|
-
exports.getEciesDecryptor = getEciesDecryptor;
|
12
|
-
const ecies_geth_1 = require("ecies-geth");
|
13
|
-
const elliptic_1 = require("elliptic");
|
14
|
-
const binary_1 = require("../binary");
|
15
|
-
const encryption_1 = require("../encryption/encryption");
|
16
|
-
const handle_1 = require("../handle");
|
17
|
-
const hadu_1 = require("./hadu");
|
18
|
-
const secp256k1 = new elliptic_1.ec('secp256k1');
|
1
|
+
import { decrypt as eciesDecrypt, encrypt as eciesEncrypt } from 'ecies-geth';
|
2
|
+
import { ec } from 'elliptic';
|
3
|
+
import { asBytes32, bytes32ToBigint, bytesFromHexString, bytesToHex } from '../binary';
|
4
|
+
import { bigintToPlaintext, ciphertextEnvelopes, encryptionSchemes, getEncryptionSchemeName, } from '../encryption/encryption';
|
5
|
+
import { computeHandle, computePrehandle } from '../handle';
|
6
|
+
import { decodeInput, encodeInput } from './hadu';
|
7
|
+
const secp256k1 = new ec('secp256k1');
|
19
8
|
// Convert an ec.KeyPair from the 'elliptic' package (assumed to have geen generated
|
20
9
|
// with the secp256k1 curve) to our Secp256k1Keypair type.
|
21
|
-
function toSecp256k1Keypair(kp) {
|
10
|
+
export function toSecp256k1Keypair(kp) {
|
22
11
|
return {
|
23
|
-
scheme:
|
12
|
+
scheme: encryptionSchemes.ecies,
|
24
13
|
kp,
|
25
14
|
encodePublicKey() {
|
26
15
|
return new Uint8Array(kp.getPublic().encode('array', false));
|
@@ -28,15 +17,15 @@ function toSecp256k1Keypair(kp) {
|
|
28
17
|
};
|
29
18
|
}
|
30
19
|
// Generate a new ephemeral keypair for reencryption.
|
31
|
-
function generateSecp256k1Keypair() {
|
20
|
+
export function generateSecp256k1Keypair() {
|
32
21
|
return toSecp256k1Keypair(secp256k1.genKeyPair());
|
33
22
|
}
|
34
23
|
// EncodePublicKey encodes an ECIES public key it's 33-byte compressed form.
|
35
|
-
function encodeSecp256k1PublicKey(pub) {
|
24
|
+
export function encodeSecp256k1PublicKey(pub) {
|
36
25
|
return new Uint8Array(pub.encodeCompressed('array'));
|
37
26
|
}
|
38
27
|
// DecodeSecp256k1PublicKey decodes a 33-byte compressed ECIES public key.
|
39
|
-
function decodeSecp256k1PublicKey(pubKeyCompressed) {
|
28
|
+
export function decodeSecp256k1PublicKey(pubKeyCompressed) {
|
40
29
|
return secp256k1.keyFromPublic(pubKeyCompressed, 'array').getPublic();
|
41
30
|
}
|
42
31
|
// DecodeSecp256k1PrivateKey returns a ECIES secp256k1 private key based on the provided byte slice which is
|
@@ -59,50 +48,50 @@ function decodeSecp256k1PublicKey(pubKeyCompressed) {
|
|
59
48
|
// We don't include any curve parameters or ECIES params, as they are assumed to
|
60
49
|
// be the ones in ecies.ECIES_AES128_SHA256 from go-ethereum.
|
61
50
|
// ref: https://github.com/ethereum/go-ethereum/blob/v1.15.0/crypto/ecies/params.go#L76-L82
|
62
|
-
function decodeSecp256k1PrivateKey(privKey) {
|
51
|
+
export function decodeSecp256k1PrivateKey(privKey) {
|
63
52
|
return toSecp256k1Keypair(secp256k1.keyFromPrivate(privKey, 'array'));
|
64
53
|
}
|
65
54
|
// Given a (usually 3rd-party known) public key, called `pubKeyA`, and an ephemeral
|
66
55
|
// private key (usually generated locally), called `privKeyB`, encrypt the `msg`
|
67
56
|
// using ECIES, with geth's parameters:
|
68
57
|
// ref: https://github.com/ethereum/go-ethereum/blob/v1.15.2/crypto/ecies/ecies.go
|
69
|
-
async function encrypt(pubKeyA, plaintext, privKeyB) {
|
58
|
+
export async function encrypt(pubKeyA, plaintext, privKeyB) {
|
70
59
|
const pubKeyABuffer = Buffer.from(pubKeyA.encode('array', false));
|
71
60
|
const privKeyBBuffer = privKeyB.kp.getPrivate().toArrayLike(Buffer, 'be', 32);
|
72
|
-
const ct = await (
|
61
|
+
const ct = await eciesEncrypt(pubKeyABuffer, Buffer.from(plaintext), {
|
73
62
|
ephemPrivateKey: privKeyBBuffer,
|
74
63
|
});
|
75
64
|
return new Uint8Array(ct);
|
76
65
|
}
|
77
|
-
function getEciesEncryptor({ pubKeyA, privKeyB }) {
|
66
|
+
export function getEciesEncryptor({ pubKeyA, privKeyB }) {
|
78
67
|
const pubKeyABuffer = Buffer.from(pubKeyA.encode('array', false));
|
79
68
|
const privKeyBBuffer = privKeyB.kp.getPrivate().toArrayLike(Buffer, 'be', 32);
|
80
69
|
return async ({ plaintext, context, }) => {
|
81
|
-
if (plaintext.scheme !==
|
82
|
-
throw new Error(`Plaintext with scheme ${
|
70
|
+
if (plaintext.scheme !== encryptionSchemes.ecies) {
|
71
|
+
throw new Error(`Plaintext with scheme ${getEncryptionSchemeName(plaintext.scheme)} cannot be encrypted with ECIES`);
|
83
72
|
}
|
84
|
-
const ptBuf = Buffer.from(
|
85
|
-
const ct = await (
|
73
|
+
const ptBuf = Buffer.from(encodeInput({ plaintext, context }));
|
74
|
+
const ct = await eciesEncrypt(pubKeyABuffer, ptBuf, {
|
86
75
|
ephemPrivateKey: privKeyBBuffer,
|
87
76
|
});
|
88
|
-
const prehandle =
|
77
|
+
const prehandle = computePrehandle({
|
89
78
|
ciphertext: ct,
|
90
79
|
handleType: plaintext.type,
|
91
80
|
indexHandle: 0,
|
92
81
|
handleVersion: 0,
|
93
82
|
});
|
94
|
-
const handle =
|
83
|
+
const handle = computeHandle({
|
95
84
|
prehandle,
|
96
85
|
context: context,
|
97
86
|
});
|
98
87
|
return {
|
99
|
-
prehandle:
|
100
|
-
handle:
|
88
|
+
prehandle: asBytes32(prehandle),
|
89
|
+
handle: asBytes32(handle),
|
101
90
|
context,
|
102
91
|
ciphertext: {
|
103
|
-
scheme:
|
92
|
+
scheme: encryptionSchemes.ecies,
|
104
93
|
type: plaintext.type,
|
105
|
-
value:
|
94
|
+
value: bytesToHex(ct),
|
106
95
|
},
|
107
96
|
};
|
108
97
|
};
|
@@ -110,26 +99,26 @@ function getEciesEncryptor({ pubKeyA, privKeyB }) {
|
|
110
99
|
// Given an ephemeral private key, called `privKeyA`, and a ciphertext `ct`,
|
111
100
|
// decrypt the ciphertext using ECIES, with geth's parameters:
|
112
101
|
// ref: https://github.com/ethereum/go-ethereum/blob/v1.15.2/crypto/ecies/ecies.go
|
113
|
-
async function decrypt(privKeyA, ciphertext) {
|
102
|
+
export async function decrypt(privKeyA, ciphertext) {
|
114
103
|
const privKeyABuffer = privKeyA.kp.getPrivate().toArrayLike(Buffer, 'be', 32);
|
115
|
-
const pt = await (
|
104
|
+
const pt = await eciesDecrypt(privKeyABuffer, Buffer.from(ciphertext));
|
116
105
|
return new Uint8Array(pt);
|
117
106
|
}
|
118
|
-
function getEciesDecryptor({ privKeyA }) {
|
107
|
+
export function getEciesDecryptor({ privKeyA }) {
|
119
108
|
const privKeyABuffer = privKeyA.kp.getPrivate().toArrayLike(Buffer, 'be', 32);
|
120
109
|
return async ({ scheme, type, value, envelope, }) => {
|
121
|
-
if (scheme !==
|
122
|
-
throw new Error(`Ciphertext with scheme ${
|
110
|
+
if (scheme !== encryptionSchemes.ecies) {
|
111
|
+
throw new Error(`Ciphertext with scheme ${getEncryptionSchemeName(scheme)} cannot be decrypted with ECIES`);
|
123
112
|
}
|
124
|
-
const ptBuf = await (
|
113
|
+
const ptBuf = await eciesDecrypt(privKeyABuffer, bytesFromHexString(value));
|
125
114
|
// If envelope field is omitted then assume HADU, only with an explicit none envelope do we assume a raw byte
|
126
115
|
// encoding as would be performed by the compute server
|
127
|
-
if (envelope ===
|
128
|
-
const bigPt =
|
129
|
-
return
|
116
|
+
if (envelope === ciphertextEnvelopes.none) {
|
117
|
+
const bigPt = bytes32ToBigint(Buffer.from(ptBuf).toString('hex'));
|
118
|
+
return bigintToPlaintext(scheme, type, bigPt);
|
130
119
|
}
|
131
|
-
const { plaintext } =
|
120
|
+
const { plaintext } = decodeInput(ptBuf.toString());
|
132
121
|
return plaintext;
|
133
122
|
};
|
134
123
|
}
|
135
|
-
//# sourceMappingURL=data:application/json;base64,
|
124
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNpZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbGl0ZS9lY2llcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsT0FBTyxJQUFJLFlBQVksRUFBRSxPQUFPLElBQUksWUFBWSxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBQzlFLE9BQU8sRUFBUyxFQUFFLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDckMsT0FBTyxFQUFFLFNBQVMsRUFBRSxlQUFlLEVBQUUsa0JBQWtCLEVBQUUsVUFBVSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQ3ZGLE9BQU8sRUFDTCxpQkFBaUIsRUFDakIsbUJBQW1CLEVBSW5CLGlCQUFpQixFQUdqQix1QkFBdUIsR0FJeEIsTUFBTSwwQkFBMEIsQ0FBQztBQUNsQyxPQUFPLEVBQUUsYUFBYSxFQUFFLGdCQUFnQixFQUFFLE1BQU0sV0FBVyxDQUFDO0FBRTVELE9BQU8sRUFBRSxXQUFXLEVBQUUsV0FBVyxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBRWxELE1BQU0sU0FBUyxHQUFHLElBQUksRUFBRSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0FBVXRDLG9GQUFvRjtBQUNwRiwwREFBMEQ7QUFDMUQsTUFBTSxVQUFVLGtCQUFrQixDQUFDLEVBQWM7SUFDL0MsT0FBTztRQUNMLE1BQU0sRUFBRSxpQkFBaUIsQ0FBQyxLQUFLO1FBQy9CLEVBQUU7UUFDRixlQUFlO1lBQ2IsT0FBTyxJQUFJLFVBQVUsQ0FBQyxFQUFFLENBQUMsU0FBUyxFQUFFLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDO1FBQy9ELENBQUM7S0FDRixDQUFDO0FBQ0osQ0FBQztBQUVELHFEQUFxRDtBQUNyRCxNQUFNLFVBQVUsd0JBQXdCO0lBQ3RDLE9BQU8sa0JBQWtCLENBQUMsU0FBUyxDQUFDLFVBQVUsRUFBRSxDQUFDLENBQUM7QUFDcEQsQ0FBQztBQUVELDRFQUE0RTtBQUM1RSxNQUFNLFVB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
|
package/dist/lite/hadu.js
CHANGED
@@ -1,41 +1,36 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
const effect_1 = require("effect");
|
7
|
-
const Schema_1 = require("effect/Schema");
|
8
|
-
const binary_1 = require("../binary");
|
9
|
-
const encryption_1 = require("../encryption");
|
10
|
-
const handle_1 = require("../handle");
|
1
|
+
import { Schema } from 'effect';
|
2
|
+
import { parseJson } from 'effect/Schema';
|
3
|
+
import { Bytes32 } from '../binary';
|
4
|
+
import { bytes32ToPlaintext, EncryptionScheme, plaintextToBytes32, SupportedFheType, } from '../encryption';
|
5
|
+
import { InputContext } from '../handle';
|
11
6
|
// HADU stands for "Host Chain, ACL, DApp, and User" it maps to the InputContext type where the aclAddress
|
12
7
|
// may actually be the singular IncoLite contract which embeds its own ACL
|
13
|
-
|
8
|
+
export const encryptionEnvelopes = {
|
14
9
|
none: 0,
|
15
10
|
hadu: 1,
|
16
11
|
};
|
17
|
-
|
18
|
-
|
19
|
-
envelope:
|
20
|
-
scheme:
|
21
|
-
context:
|
22
|
-
plaintext:
|
23
|
-
type:
|
12
|
+
export const EncryptionEnvelope = Schema.Literal(...Object.values(encryptionEnvelopes));
|
13
|
+
export const HaduInput = parseJson(Schema.Struct({
|
14
|
+
envelope: Schema.Literal(encryptionEnvelopes.hadu),
|
15
|
+
scheme: EncryptionScheme,
|
16
|
+
context: InputContext,
|
17
|
+
plaintext: Bytes32,
|
18
|
+
type: SupportedFheType,
|
24
19
|
}));
|
25
|
-
function encodeInput({ plaintext, context }) {
|
26
|
-
return
|
27
|
-
envelope:
|
20
|
+
export function encodeInput({ plaintext, context }) {
|
21
|
+
return Schema.encodeSync(HaduInput)({
|
22
|
+
envelope: encryptionEnvelopes.hadu,
|
28
23
|
scheme: plaintext.scheme,
|
29
24
|
type: plaintext.type,
|
30
|
-
plaintext:
|
25
|
+
plaintext: plaintextToBytes32(plaintext),
|
31
26
|
context,
|
32
27
|
});
|
33
28
|
}
|
34
|
-
function decodeInput(json) {
|
35
|
-
const { scheme, context, plaintext, type } =
|
29
|
+
export function decodeInput(json) {
|
30
|
+
const { scheme, context, plaintext, type } = Schema.decodeSync(HaduInput)(json);
|
36
31
|
return {
|
37
|
-
plaintext:
|
32
|
+
plaintext: bytes32ToPlaintext(plaintext, scheme, type),
|
38
33
|
context,
|
39
34
|
};
|
40
35
|
}
|
41
|
-
//# sourceMappingURL=data:application/json;base64,
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGFkdS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saXRlL2hhZHUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUNoQyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDcEMsT0FBTyxFQUNMLGtCQUFrQixFQUNsQixnQkFBZ0IsRUFDaEIsa0JBQWtCLEVBRWxCLGdCQUFnQixHQUNqQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBRXpDLDBHQUEwRztBQUMxRywwRUFBMEU7QUFFMUUsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUc7SUFDakMsSUFBSSxFQUFFLENBQUM7SUFDUCxJQUFJLEVBQUUsQ0FBQztDQUNDLENBQUM7QUFLWCxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDLENBQUM7QUFFeEYsTUFBTSxDQUFDLE1BQU0sU0FBUyxHQUFHLFNBQVMsQ0FDaEMsTUFBTSxDQUFDLE1BQU0sQ0FBQztJQUNaLFFBQVEsRUFBRSxNQUFNLENBQUMsT0FBTyxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQztJQUNsRCxNQUFNLEVBQUUsZ0JBQWdCO0lBQ3hCLE9BQU8sRUFBRSxZQUFZO0lBQ3JCLFNBQVMsRUFBRSxPQUFPO0lBQ2xCLElBQUksRUFBRSxnQkFBZ0I7Q0FDdkIsQ0FBQyxDQUNILENBQUM7QUFJRixNQUFNLFVBQVUsV0FBVyxDQUFDLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBd0I7SUFDdEUsT0FBTyxNQUFNLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ2xDLFFBQVEsRUFBRSxtQkFBbUIsQ0FBQyxJQUFJO1FBQ2xDLE1BQU0sRUFBRSxTQUFTLENBQUMsTUFBTTtRQUN4QixJQUFJLEVBQUUsU0FBUyxDQUFDLElBQUk7UUFDcEIsU0FBUyxFQUFFLGtCQUFrQixDQUFDLFNBQVMsQ0FBQztRQUN4QyxPQUFPO0tBQ1IsQ0FBQyxDQUFDO0FBQ0wsQ0FBQztBQUVELE1BQU0sVUFBVSxXQUFXLENBQUMsSUFBWTtJQUN0QyxNQUFNLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUFFLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNoRixPQUFPO1FBQ0wsU0FBUyxFQUFFLGtCQUFrQixDQUFDLFNBQVMsRUFBRSxNQUFNLEVBQUUsSUFBSSxDQUFDO1FBQ3RELE9BQU87S0FDUixDQUFDO0FBQ0osQ0FBQyJ9
|