@airgap/aeternity 0.13.45-beta.3 → 0.13.45-beta.5
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/package.json +4 -4
- package/v0/index.js +7 -7
- package/v0/index.js.map +1 -1
- package/v0/protocol/AeternityAddress.js +18 -27
- package/v0/protocol/AeternityAddress.js.map +1 -1
- package/v0/protocol/AeternityCryptoClient.js +84 -21
- package/v0/protocol/AeternityCryptoClient.js.map +1 -1
- package/v0/protocol/AeternityProtocol.js +657 -341
- package/v0/protocol/AeternityProtocol.js.map +1 -1
- package/v0/protocol/AeternityProtocolOptions.js +93 -22
- package/v0/protocol/AeternityProtocolOptions.js.map +1 -1
- package/v0/serializer/validators/transaction-validator.js +83 -30
- package/v0/serializer/validators/transaction-validator.js.map +1 -1
- package/v0/serializer/validators/validators.js +67 -19
- package/v0/serializer/validators/validators.js.map +1 -1
- package/v1/block-explorer/AeternityBlockExplorer.js +61 -12
- package/v1/block-explorer/AeternityBlockExplorer.js.map +1 -1
- package/v1/data/AeternityAddress.js +13 -12
- package/v1/data/AeternityAddress.js.map +1 -1
- package/v1/index.js +3 -3
- package/v1/index.js.map +1 -1
- package/v1/module/AeternityModule.d.ts +1 -1
- package/v1/module/AeternityModule.js +95 -37
- package/v1/module/AeternityModule.js.map +1 -1
- package/v1/module.js +3 -2
- package/v1/module.js.map +1 -1
- package/v1/protocol/AeternityCryptoClient.js +84 -21
- package/v1/protocol/AeternityCryptoClient.js.map +1 -1
- package/v1/protocol/AeternityProtocol.js +497 -282
- package/v1/protocol/AeternityProtocol.js.map +1 -1
- package/v1/serializer/v3/schemas/converter/transaction-converter.js +20 -8
- package/v1/serializer/v3/schemas/converter/transaction-converter.js.map +1 -1
- package/v1/serializer/v3/serializer-companion.js +148 -69
- package/v1/serializer/v3/serializer-companion.js.map +1 -1
- package/v1/serializer/v3/validators/transaction-validator.js +63 -15
- package/v1/serializer/v3/validators/transaction-validator.js.map +1 -1
- package/v1/serializer/v3/validators/validators.js +67 -19
- package/v1/serializer/v3/validators/validators.js.map +1 -1
- package/v1/types/crypto.d.ts +1 -1
- package/v1/types/protocol.d.ts +1 -1
- package/v1/utils/convert.js +17 -26
- package/v1/utils/convert.js.map +1 -1
- package/v1/utils/key.js +10 -9
- package/v1/utils/key.js.map +1 -1
- package/v1/utils/signature.js +7 -6
- package/v1/utils/signature.js.map +1 -1
- package/v1/utils/transaction.d.ts +1 -0
- package/v1/utils/transaction.js +17 -26
- package/v1/utils/transaction.js.map +1 -1
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@airgap/aeternity",
|
|
3
|
-
"version": "0.13.45-beta.
|
|
3
|
+
"version": "0.13.45-beta.5",
|
|
4
4
|
"description": "The @airgap/aeternity is an Aeternity implementation of the ICoinProtocol interface from @airgap/coinlib-core.",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"airgap",
|
|
@@ -30,9 +30,9 @@
|
|
|
30
30
|
},
|
|
31
31
|
"author": "Papers AG <contact@papers.ch> (https://papers.ch)",
|
|
32
32
|
"dependencies": {
|
|
33
|
-
"@airgap/coinlib-core": "^0.13.45-beta.
|
|
34
|
-
"@airgap/module-kit": "^0.13.45-beta.
|
|
35
|
-
"@airgap/serializer": "^0.13.45-beta.
|
|
33
|
+
"@airgap/coinlib-core": "^0.13.45-beta.5",
|
|
34
|
+
"@airgap/module-kit": "^0.13.45-beta.5",
|
|
35
|
+
"@airgap/serializer": "^0.13.45-beta.5",
|
|
36
36
|
"@stablelib/ed25519": "^1.0.3"
|
|
37
37
|
},
|
|
38
38
|
"localDependencies": {},
|
package/v0/index.js
CHANGED
|
@@ -1,19 +1,19 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.AeternityAddress = exports.AeternityProtocolNetwork = exports.AeternalBlockExplorer = exports.AeternityProtocolOptions = exports.AeternityCryptoClient = exports.AeternityProtocol = void 0;
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
4
|
+
var coinlib_core_1 = require("@airgap/coinlib-core");
|
|
5
|
+
var serializer_1 = require("@airgap/serializer");
|
|
6
|
+
var AeternityAddress_1 = require("./protocol/AeternityAddress");
|
|
7
7
|
Object.defineProperty(exports, "AeternityAddress", { enumerable: true, get: function () { return AeternityAddress_1.AeternityAddress; } });
|
|
8
|
-
|
|
8
|
+
var AeternityCryptoClient_1 = require("./protocol/AeternityCryptoClient");
|
|
9
9
|
Object.defineProperty(exports, "AeternityCryptoClient", { enumerable: true, get: function () { return AeternityCryptoClient_1.AeternityCryptoClient; } });
|
|
10
|
-
|
|
10
|
+
var AeternityProtocol_1 = require("./protocol/AeternityProtocol");
|
|
11
11
|
Object.defineProperty(exports, "AeternityProtocol", { enumerable: true, get: function () { return AeternityProtocol_1.AeternityProtocol; } });
|
|
12
|
-
|
|
12
|
+
var AeternityProtocolOptions_1 = require("./protocol/AeternityProtocolOptions");
|
|
13
13
|
Object.defineProperty(exports, "AeternalBlockExplorer", { enumerable: true, get: function () { return AeternityProtocolOptions_1.AeternalBlockExplorer; } });
|
|
14
14
|
Object.defineProperty(exports, "AeternityProtocolNetwork", { enumerable: true, get: function () { return AeternityProtocolOptions_1.AeternityProtocolNetwork; } });
|
|
15
15
|
Object.defineProperty(exports, "AeternityProtocolOptions", { enumerable: true, get: function () { return AeternityProtocolOptions_1.AeternityProtocolOptions; } });
|
|
16
|
-
|
|
16
|
+
var transaction_validator_1 = require("./serializer/validators/transaction-validator");
|
|
17
17
|
// Serializer
|
|
18
18
|
serializer_1.Serializer.addSchema(serializer_1.IACMessageType.TransactionSignRequest, { schema: require('./serializer/schemas/v2/transaction-sign-request-aeternity.json') }, coinlib_core_1.MainProtocolSymbols.AE);
|
|
19
19
|
serializer_1.Serializer.addSchema(serializer_1.IACMessageType.TransactionSignResponse, { schema: require('./serializer/schemas/v2/transaction-sign-response-aeternity.json') }, coinlib_core_1.MainProtocolSymbols.AE);
|
package/v0/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/v0/index.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/v0/index.ts"],"names":[],"mappings":";;;AAAA,qDAA0D;AAC1D,iDAA6E;AAE7E,gEAA8D;AAe5D,iGAfO,mCAAgB,OAeP;AAdlB,0EAAwE;AAUtE,sGAVO,6CAAqB,OAUP;AATvB,kEAAgE;AAQ9D,kGARO,qCAAiB,OAQP;AAPnB,gFAA+H;AAU7H,sGAVO,gDAAqB,OAUP;AACrB,yGAX8B,mDAAwB,OAW9B;AAFxB,yGATwD,mDAAwB,OASxD;AAR1B,uFAA4I;AAiB5I,aAAa;AAEb,uBAAU,CAAC,SAAS,CAClB,2BAAc,CAAC,sBAAsB,EACrC,EAAE,MAAM,EAAE,OAAO,CAAC,iEAAiE,CAAC,EAAE,EACtF,kCAAmB,CAAC,EAAE,CACvB,CAAA;AACD,uBAAU,CAAC,SAAS,CAClB,2BAAc,CAAC,uBAAuB,EACtC,EAAE,MAAM,EAAE,OAAO,CAAC,kEAAkE,CAAC,EAAE,EACvF,kCAAmB,CAAC,EAAE,CACvB,CAAA;AAED,yBAAY,CAAC,SAAS,CACpB,2BAAc,CAAC,sBAAsB,EACrC,EAAE,MAAM,EAAE,OAAO,CAAC,iEAAiE,CAAC,EAAE,EACtF,kCAAmB,CAAC,EAAE,CACvB,CAAA;AACD,yBAAY,CAAC,SAAS,CACpB,2BAAc,CAAC,uBAAuB,EACtC,EAAE,MAAM,EAAE,OAAO,CAAC,kEAAkE,CAAC,EAAE,EACvF,kCAAmB,CAAC,EAAE,CACvB,CAAA;AAED,uBAAU,CAAC,YAAY,CAAC,kCAAmB,CAAC,EAAE,EAAE,IAAI,8DAAsC,EAAE,CAAC,CAAA;AAC7F,yBAAY,CAAC,YAAY,CAAC,kCAAmB,CAAC,EAAE,EAAE,IAAI,4DAAoC,EAAE,CAAC,CAAA"}
|
|
@@ -15,37 +15,28 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
|
|
|
15
15
|
}) : function(o, v) {
|
|
16
16
|
o["default"] = v;
|
|
17
17
|
});
|
|
18
|
-
var __importStar = (this && this.__importStar) ||
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
return ownKeys(o);
|
|
26
|
-
};
|
|
27
|
-
return function (mod) {
|
|
28
|
-
if (mod && mod.__esModule) return mod;
|
|
29
|
-
var result = {};
|
|
30
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
-
__setModuleDefault(result, mod);
|
|
32
|
-
return result;
|
|
33
|
-
};
|
|
34
|
-
})();
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
35
25
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
26
|
exports.AeternityAddress = void 0;
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
27
|
+
var bs58check = __importStar(require("@airgap/coinlib-core/dependencies/src/bs58check-2.1.2/index"));
|
|
28
|
+
var AeternityAddress = /** @class */ (function () {
|
|
29
|
+
function AeternityAddress(value) {
|
|
40
30
|
this.value = value;
|
|
41
31
|
}
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
return new AeternityAddress(
|
|
45
|
-
}
|
|
46
|
-
asString() {
|
|
32
|
+
AeternityAddress.from = function (publicKey) {
|
|
33
|
+
var base58 = bs58check.encode(Buffer.from(publicKey, 'hex'));
|
|
34
|
+
return new AeternityAddress("ak_".concat(base58));
|
|
35
|
+
};
|
|
36
|
+
AeternityAddress.prototype.asString = function () {
|
|
47
37
|
return this.value;
|
|
48
|
-
}
|
|
49
|
-
|
|
38
|
+
};
|
|
39
|
+
return AeternityAddress;
|
|
40
|
+
}());
|
|
50
41
|
exports.AeternityAddress = AeternityAddress;
|
|
51
42
|
//# sourceMappingURL=AeternityAddress.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AeternityAddress.js","sourceRoot":"","sources":["../../../src/v0/protocol/AeternityAddress.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"AeternityAddress.js","sourceRoot":"","sources":["../../../src/v0/protocol/AeternityAddress.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,qGAAwF;AAExF;IACE,0BAAqC,KAAa;QAAb,UAAK,GAAL,KAAK,CAAQ;IAAG,CAAC;IAExC,qBAAI,GAAlB,UAAmB,SAAiB;QAClC,IAAM,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC,CAAA;QAE9D,OAAO,IAAI,gBAAgB,CAAC,aAAM,MAAM,CAAE,CAAC,CAAA;IAC7C,CAAC;IAEM,mCAAQ,GAAf;QACE,OAAO,IAAI,CAAC,KAAK,CAAA;IACnB,CAAC;IACH,uBAAC;AAAD,CAAC,AAZD,IAYC;AAZY,4CAAgB"}
|
|
@@ -1,32 +1,95 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __extends = (this && this.__extends) || (function () {
|
|
3
|
+
var extendStatics = function (d, b) {
|
|
4
|
+
extendStatics = Object.setPrototypeOf ||
|
|
5
|
+
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
6
|
+
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
7
|
+
return extendStatics(d, b);
|
|
8
|
+
};
|
|
9
|
+
return function (d, b) {
|
|
10
|
+
if (typeof b !== "function" && b !== null)
|
|
11
|
+
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
12
|
+
extendStatics(d, b);
|
|
13
|
+
function __() { this.constructor = d; }
|
|
14
|
+
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
15
|
+
};
|
|
16
|
+
})();
|
|
17
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
18
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
19
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
20
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
21
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
22
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
23
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
24
|
+
});
|
|
25
|
+
};
|
|
26
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
27
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
28
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
29
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
30
|
+
function step(op) {
|
|
31
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
32
|
+
while (_) try {
|
|
33
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
34
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
35
|
+
switch (op[0]) {
|
|
36
|
+
case 0: case 1: t = op; break;
|
|
37
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
38
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
39
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
40
|
+
default:
|
|
41
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
42
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
43
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
44
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
45
|
+
if (t[2]) _.ops.pop();
|
|
46
|
+
_.trys.pop(); continue;
|
|
47
|
+
}
|
|
48
|
+
op = body.call(thisArg, _);
|
|
49
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
50
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
51
|
+
}
|
|
52
|
+
};
|
|
2
53
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
54
|
exports.AeternityCryptoClient = void 0;
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
55
|
+
var errors_1 = require("@airgap/coinlib-core/errors");
|
|
56
|
+
var coinlib_error_1 = require("@airgap/coinlib-core/errors/coinlib-error");
|
|
57
|
+
var Ed25519CryptoClient_1 = require("@airgap/coinlib-core/protocols/Ed25519CryptoClient");
|
|
58
|
+
var ed25519_1 = require("@stablelib/ed25519");
|
|
59
|
+
var personalMessageToBinary = function (message) {
|
|
60
|
+
var prefix = Buffer.from('Æternity Signed Message:\n', 'utf8');
|
|
61
|
+
var messageBuffer = Buffer.from(message, 'utf8');
|
|
11
62
|
if (messageBuffer.length >= 0xfd) {
|
|
12
63
|
throw new errors_1.InvalidValueError(coinlib_error_1.Domain.AETERNITY, 'message too long');
|
|
13
64
|
}
|
|
14
65
|
return Buffer.concat([Buffer.from([prefix.length]), prefix, Buffer.from([messageBuffer.length]), messageBuffer]);
|
|
15
66
|
};
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
async signMessage(message, keypair) {
|
|
21
|
-
const messageBuffer = personalMessageToBinary(message);
|
|
22
|
-
const rawSignature = (0, ed25519_1.sign)(Buffer.from(keypair.privateKey, 'hex'), messageBuffer);
|
|
23
|
-
return Buffer.from(rawSignature).toString('hex');
|
|
24
|
-
}
|
|
25
|
-
async verifyMessage(message, signature, publicKey) {
|
|
26
|
-
const rawSignature = Buffer.from(signature, 'hex');
|
|
27
|
-
const messageBuffer = personalMessageToBinary(message);
|
|
28
|
-
return (0, ed25519_1.verify)(Buffer.from(publicKey, 'hex'), messageBuffer, rawSignature);
|
|
67
|
+
var AeternityCryptoClient = /** @class */ (function (_super) {
|
|
68
|
+
__extends(AeternityCryptoClient, _super);
|
|
69
|
+
function AeternityCryptoClient() {
|
|
70
|
+
return _super.call(this) || this;
|
|
29
71
|
}
|
|
30
|
-
|
|
72
|
+
AeternityCryptoClient.prototype.signMessage = function (message, keypair) {
|
|
73
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
74
|
+
var messageBuffer, rawSignature;
|
|
75
|
+
return __generator(this, function (_a) {
|
|
76
|
+
messageBuffer = personalMessageToBinary(message);
|
|
77
|
+
rawSignature = (0, ed25519_1.sign)(Buffer.from(keypair.privateKey, 'hex'), messageBuffer);
|
|
78
|
+
return [2 /*return*/, Buffer.from(rawSignature).toString('hex')];
|
|
79
|
+
});
|
|
80
|
+
});
|
|
81
|
+
};
|
|
82
|
+
AeternityCryptoClient.prototype.verifyMessage = function (message, signature, publicKey) {
|
|
83
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
84
|
+
var rawSignature, messageBuffer;
|
|
85
|
+
return __generator(this, function (_a) {
|
|
86
|
+
rawSignature = Buffer.from(signature, 'hex');
|
|
87
|
+
messageBuffer = personalMessageToBinary(message);
|
|
88
|
+
return [2 /*return*/, (0, ed25519_1.verify)(Buffer.from(publicKey, 'hex'), messageBuffer, rawSignature)];
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
};
|
|
92
|
+
return AeternityCryptoClient;
|
|
93
|
+
}(Ed25519CryptoClient_1.Ed25519CryptoClient));
|
|
31
94
|
exports.AeternityCryptoClient = AeternityCryptoClient;
|
|
32
95
|
//# sourceMappingURL=AeternityCryptoClient.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AeternityCryptoClient.js","sourceRoot":"","sources":["../../../src/v0/protocol/AeternityCryptoClient.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"AeternityCryptoClient.js","sourceRoot":"","sources":["../../../src/v0/protocol/AeternityCryptoClient.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,sDAA+D;AAC/D,2EAAkE;AAClE,0FAAwF;AACxF,8CAAiD;AAEjD,IAAM,uBAAuB,GAAG,UAAC,OAAe;IAC9C,IAAM,MAAM,GAAW,MAAM,CAAC,IAAI,CAAC,6BAA6B,EAAE,MAAM,CAAC,CAAA;IACzE,IAAM,aAAa,GAAW,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC,CAAA;IAC1D,IAAI,aAAa,CAAC,MAAM,IAAI,IAAI,EAAE;QAChC,MAAM,IAAI,0BAAiB,CAAC,sBAAM,CAAC,SAAS,EAAE,kBAAkB,CAAC,CAAA;KAClE;IAED,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC,CAAA;AAClH,CAAC,CAAA;AAED;IAA2C,yCAAmB;IAC5D;eACE,iBAAO;IACT,CAAC;IAEY,2CAAW,GAAxB,UAAyB,OAAe,EAAE,OAA+B;;;;gBACjE,aAAa,GAAW,uBAAuB,CAAC,OAAO,CAAC,CAAA;gBACxD,YAAY,GAAe,IAAA,cAAI,EAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,KAAK,CAAC,EAAE,aAAa,CAAC,CAAA;gBAE5F,sBAAO,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAA;;;KACjD;IAEY,6CAAa,GAA1B,UAA2B,OAAe,EAAE,SAAiB,EAAE,SAAiB;;;;gBACxE,YAAY,GAAW,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,CAAA;gBACpD,aAAa,GAAW,uBAAuB,CAAC,OAAO,CAAC,CAAA;gBAE9D,sBAAO,IAAA,gBAAM,EAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,EAAE,aAAa,EAAE,YAAY,CAAC,EAAA;;;KAC1E;IACH,4BAAC;AAAD,CAAC,AAlBD,CAA2C,yCAAmB,GAkB7D;AAlBY,sDAAqB"}
|