@airgap/aeternity 0.13.11-beta.1 → 0.13.11-beta.3

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.
Files changed (103) hide show
  1. package/index.d.ts +1 -0
  2. package/index.js +18 -0
  3. package/index.js.map +1 -0
  4. package/package.json +1 -5
  5. package/v0/index.d.ts +8 -0
  6. package/v0/index.js +24 -0
  7. package/v0/index.js.map +1 -0
  8. package/v0/protocol/AeternityAddress.d.ts +7 -0
  9. package/v0/protocol/AeternityAddress.js +42 -0
  10. package/v0/protocol/AeternityAddress.js.map +1 -0
  11. package/v0/protocol/AeternityCryptoClient.d.ts +8 -0
  12. package/v0/protocol/AeternityCryptoClient.js +95 -0
  13. package/v0/protocol/AeternityCryptoClient.js.map +1 -0
  14. package/v0/protocol/AeternityProtocol.d.ts +102 -0
  15. package/v0/protocol/AeternityProtocol.js +725 -0
  16. package/v0/protocol/AeternityProtocol.js.map +1 -0
  17. package/v0/protocol/AeternityProtocolOptions.d.ts +17 -0
  18. package/v0/protocol/AeternityProtocolOptions.js +109 -0
  19. package/v0/protocol/AeternityProtocolOptions.js.map +1 -0
  20. package/v0/protocol/AeternityTypes.d.ts +16 -0
  21. package/v0/protocol/AeternityTypes.js +3 -0
  22. package/v0/protocol/AeternityTypes.js.map +1 -0
  23. package/v0/serializer/schemas/v2/transaction-sign-request-aeternity.json +32 -0
  24. package/v0/serializer/schemas/v2/transaction-sign-response-aeternity.json +19 -0
  25. package/v0/serializer/schemas/v3/transaction-sign-request-aeternity.json +32 -0
  26. package/v0/serializer/schemas/v3/transaction-sign-response-aeternity.json +19 -0
  27. package/v0/serializer/validators/transaction-validator.d.ts +15 -0
  28. package/v0/serializer/validators/transaction-validator.js +116 -0
  29. package/v0/serializer/validators/transaction-validator.js.map +1 -0
  30. package/v0/serializer/validators/validators.d.ts +1 -0
  31. package/v0/serializer/validators/validators.js +103 -0
  32. package/v0/serializer/validators/validators.js.map +1 -0
  33. package/v0/types/signed-transaction-aeternity.d.ts +5 -0
  34. package/v0/types/signed-transaction-aeternity.js +3 -0
  35. package/v0/types/signed-transaction-aeternity.js.map +1 -0
  36. package/v0/types/transaction-aeternity.d.ts +4 -0
  37. package/v0/types/transaction-aeternity.js +3 -0
  38. package/v0/types/transaction-aeternity.js.map +1 -0
  39. package/v0/types/unsigned-transaction-aeternity.d.ts +9 -0
  40. package/v0/types/unsigned-transaction-aeternity.js +3 -0
  41. package/v0/types/unsigned-transaction-aeternity.js.map +1 -0
  42. package/v1/block-explorer/AeternityBlockExplorer.d.ts +9 -0
  43. package/v1/block-explorer/AeternityBlockExplorer.js +74 -0
  44. package/v1/block-explorer/AeternityBlockExplorer.js.map +1 -0
  45. package/v1/data/AeternityAddress.d.ts +8 -0
  46. package/v1/data/AeternityAddress.js +23 -0
  47. package/v1/data/AeternityAddress.js.map +1 -0
  48. package/v1/index.d.ts +13 -0
  49. package/v1/index.js +11 -0
  50. package/v1/index.js.map +1 -0
  51. package/v1/module/AeternityModule.d.ts +15 -0
  52. package/v1/module/AeternityModule.js +107 -0
  53. package/v1/module/AeternityModule.js.map +1 -0
  54. package/v1/module.d.ts +3 -0
  55. package/v1/module.js +24 -0
  56. package/v1/module.js.map +1 -0
  57. package/v1/protocol/AeternityCryptoClient.d.ts +8 -0
  58. package/v1/protocol/AeternityCryptoClient.js +95 -0
  59. package/v1/protocol/AeternityCryptoClient.js.map +1 -0
  60. package/v1/protocol/AeternityProtocol.d.ts +52 -0
  61. package/v1/protocol/AeternityProtocol.js +584 -0
  62. package/v1/protocol/AeternityProtocol.js.map +1 -0
  63. package/v1/serializer/v3/schemas/converter/transaction-converter.d.ts +7 -0
  64. package/v1/serializer/v3/schemas/converter/transaction-converter.js +37 -0
  65. package/v1/serializer/v3/schemas/converter/transaction-converter.js.map +1 -0
  66. package/v1/serializer/v3/schemas/definitions/transaction-sign-request-aeternity.d.ts +4 -0
  67. package/v1/serializer/v3/schemas/definitions/transaction-sign-request-aeternity.js +3 -0
  68. package/v1/serializer/v3/schemas/definitions/transaction-sign-request-aeternity.js.map +1 -0
  69. package/v1/serializer/v3/schemas/definitions/transaction-sign-response-aeternity.d.ts +3 -0
  70. package/v1/serializer/v3/schemas/definitions/transaction-sign-response-aeternity.js +3 -0
  71. package/v1/serializer/v3/schemas/definitions/transaction-sign-response-aeternity.js.map +1 -0
  72. package/v1/serializer/v3/schemas/generated/transaction-sign-request-aeternity.json +32 -0
  73. package/v1/serializer/v3/schemas/generated/transaction-sign-response-aeternity.json +19 -0
  74. package/v1/serializer/v3/serializer-companion.d.ts +14 -0
  75. package/v1/serializer/v3/serializer-companion.js +173 -0
  76. package/v1/serializer/v3/serializer-companion.js.map +1 -0
  77. package/v1/serializer/v3/validators/transaction-validator.d.ts +7 -0
  78. package/v1/serializer/v3/validators/transaction-validator.js +91 -0
  79. package/v1/serializer/v3/validators/transaction-validator.js.map +1 -0
  80. package/v1/serializer/v3/validators/validators.d.ts +5 -0
  81. package/v1/serializer/v3/validators/validators.js +106 -0
  82. package/v1/serializer/v3/validators/validators.js.map +1 -0
  83. package/v1/types/crypto.d.ts +2 -0
  84. package/v1/types/crypto.js +3 -0
  85. package/v1/types/crypto.js.map +1 -0
  86. package/v1/types/protocol.d.ts +8 -0
  87. package/v1/types/protocol.js +3 -0
  88. package/v1/types/protocol.js.map +1 -0
  89. package/v1/types/transaction.d.ts +11 -0
  90. package/v1/types/transaction.js +3 -0
  91. package/v1/types/transaction.js.map +1 -0
  92. package/v1/utils/convert.d.ts +3 -0
  93. package/v1/utils/convert.js +57 -0
  94. package/v1/utils/convert.js.map +1 -0
  95. package/v1/utils/key.d.ts +3 -0
  96. package/v1/utils/key.js +33 -0
  97. package/v1/utils/key.js.map +1 -0
  98. package/v1/utils/signature.d.ts +2 -0
  99. package/v1/utils/signature.js +24 -0
  100. package/v1/utils/signature.js.map +1 -0
  101. package/v1/utils/transaction.d.ts +3 -0
  102. package/v1/utils/transaction.js +56 -0
  103. package/v1/utils/transaction.js.map +1 -0
@@ -0,0 +1,74 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __generator = (this && this.__generator) || function (thisArg, body) {
12
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
13
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
14
+ function verb(n) { return function (v) { return step([n, v]); }; }
15
+ function step(op) {
16
+ if (f) throw new TypeError("Generator is already executing.");
17
+ while (_) try {
18
+ 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;
19
+ if (y = 0, t) op = [op[0] & 2, t.value];
20
+ switch (op[0]) {
21
+ case 0: case 1: t = op; break;
22
+ case 4: _.label++; return { value: op[1], done: false };
23
+ case 5: _.label++; y = op[1]; op = [0]; continue;
24
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
25
+ default:
26
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
27
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
28
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
29
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
30
+ if (t[2]) _.ops.pop();
31
+ _.trys.pop(); continue;
32
+ }
33
+ op = body.call(thisArg, _);
34
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
35
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
36
+ }
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.AeternityBlockExplorer = void 0;
40
+ var BLOCK_EXPLORER_URL = 'https://explorer.aeternity.io';
41
+ var AeternityBlockExplorer = /** @class */ (function () {
42
+ function AeternityBlockExplorer(url) {
43
+ if (url === void 0) { url = BLOCK_EXPLORER_URL; }
44
+ this.url = url;
45
+ this.metadata = {
46
+ name: 'æternity Explorer',
47
+ url: this.url
48
+ };
49
+ }
50
+ AeternityBlockExplorer.prototype.getMetadata = function () {
51
+ return __awaiter(this, void 0, void 0, function () {
52
+ return __generator(this, function (_a) {
53
+ return [2 /*return*/, this.metadata];
54
+ });
55
+ });
56
+ };
57
+ AeternityBlockExplorer.prototype.createAddressUrl = function (address) {
58
+ return __awaiter(this, void 0, void 0, function () {
59
+ return __generator(this, function (_a) {
60
+ return [2 /*return*/, "".concat(this.url, "/account/transactions/").concat(address)];
61
+ });
62
+ });
63
+ };
64
+ AeternityBlockExplorer.prototype.createTransactionUrl = function (transactionId) {
65
+ return __awaiter(this, void 0, void 0, function () {
66
+ return __generator(this, function (_a) {
67
+ return [2 /*return*/, "".concat(this.url, "/transactions/").concat(transactionId)];
68
+ });
69
+ });
70
+ };
71
+ return AeternityBlockExplorer;
72
+ }());
73
+ exports.AeternityBlockExplorer = AeternityBlockExplorer;
74
+ //# sourceMappingURL=AeternityBlockExplorer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AeternityBlockExplorer.js","sourceRoot":"","sources":["../../../src/v1/block-explorer/AeternityBlockExplorer.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,IAAM,kBAAkB,GAAW,+BAA+B,CAAA;AAElE;IACE,gCAAmC,GAAgC;QAAhC,oBAAA,EAAA,wBAAgC;QAAhC,QAAG,GAAH,GAAG,CAA6B;QAElD,aAAQ,GAA0B;YACjD,IAAI,EAAE,mBAAmB;YACzB,GAAG,EAAE,IAAI,CAAC,GAAG;SACd,CAAA;IALqE,CAAC;IAO1D,4CAAW,GAAxB;;;gBACE,sBAAO,IAAI,CAAC,QAAQ,EAAA;;;KACrB;IAEY,iDAAgB,GAA7B,UAA8B,OAAe;;;gBAC3C,sBAAO,UAAG,IAAI,CAAC,GAAG,mCAAyB,OAAO,CAAE,EAAA;;;KACrD;IACY,qDAAoB,GAAjC,UAAkC,aAAqB;;;gBACrD,sBAAO,UAAG,IAAI,CAAC,GAAG,2BAAiB,aAAa,CAAE,EAAA;;;KACnD;IACH,6BAAC;AAAD,CAAC,AAlBD,IAkBC;AAlBY,wDAAsB"}
@@ -0,0 +1,8 @@
1
+ import { PublicKey } from '@airgap/module-kit';
2
+ export declare class AeternityAddress {
3
+ private readonly value;
4
+ private constructor();
5
+ static from(publicKey: string | PublicKey): AeternityAddress;
6
+ asString(): string;
7
+ toPublicKey(): PublicKey;
8
+ }
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AeternityAddress = void 0;
4
+ var module_kit_1 = require("@airgap/module-kit");
5
+ var key_1 = require("../utils/key");
6
+ var AeternityAddress = /** @class */ (function () {
7
+ function AeternityAddress(value) {
8
+ this.value = value;
9
+ }
10
+ AeternityAddress.from = function (publicKey) {
11
+ var _publicKey = typeof publicKey === 'string' ? (0, key_1.aePublicKey)(publicKey) : publicKey;
12
+ return new AeternityAddress((0, key_1.convertPublicKey)(_publicKey, 'encoded').value);
13
+ };
14
+ AeternityAddress.prototype.asString = function () {
15
+ return this.value;
16
+ };
17
+ AeternityAddress.prototype.toPublicKey = function () {
18
+ return (0, module_kit_1.newPublicKey)(this.value, 'encoded');
19
+ };
20
+ return AeternityAddress;
21
+ }());
22
+ exports.AeternityAddress = AeternityAddress;
23
+ //# sourceMappingURL=AeternityAddress.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AeternityAddress.js","sourceRoot":"","sources":["../../../src/v1/data/AeternityAddress.ts"],"names":[],"mappings":";;;AAAA,iDAA4D;AAE5D,oCAA4D;AAE5D;IACE,0BAAqC,KAAa;QAAb,UAAK,GAAL,KAAK,CAAQ;IAAG,CAAC;IAExC,qBAAI,GAAlB,UAAmB,SAA6B;QAC9C,IAAM,UAAU,GAAG,OAAO,SAAS,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAA,iBAAW,EAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAA;QAErF,OAAO,IAAI,gBAAgB,CAAC,IAAA,sBAAgB,EAAC,UAAU,EAAE,SAAS,CAAC,CAAC,KAAK,CAAC,CAAA;IAC5E,CAAC;IAEM,mCAAQ,GAAf;QACE,OAAO,IAAI,CAAC,KAAK,CAAA;IACnB,CAAC;IAEM,sCAAW,GAAlB;QACE,OAAO,IAAA,yBAAY,EAAC,IAAI,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;IAC5C,CAAC;IACH,uBAAC;AAAD,CAAC,AAhBD,IAgBC;AAhBY,4CAAgB"}
package/v1/index.d.ts ADDED
@@ -0,0 +1,13 @@
1
+ import { AeternityBlockExplorer } from './block-explorer/AeternityBlockExplorer';
2
+ import { AeternityModule } from './module/AeternityModule';
3
+ import { AeternityProtocol, createAeternityProtocol, createAeternityProtocolOptions } from './protocol/AeternityProtocol';
4
+ import { AeternityTransactionSignRequest } from './serializer/v3/schemas/definitions/transaction-sign-request-aeternity';
5
+ import { AeternityTransactionSignResponse } from './serializer/v3/schemas/definitions/transaction-sign-response-aeternity';
6
+ import { AeternityCryptoConfiguration } from './types/crypto';
7
+ import { AeternityProtocolNetwork, AeternityProtocolOptions, AeternityUnits } from './types/protocol';
8
+ import { AeternitySignedTransaction, AeternityUnsignedTransaction } from './types/transaction';
9
+ export { AeternityModule };
10
+ export { AeternityProtocol, createAeternityProtocol, createAeternityProtocolOptions };
11
+ export { AeternityBlockExplorer };
12
+ export { AeternityCryptoConfiguration, AeternityUnits, AeternityProtocolOptions, AeternityProtocolNetwork, AeternityUnsignedTransaction, AeternitySignedTransaction };
13
+ export { AeternityTransactionSignRequest, AeternityTransactionSignResponse };
package/v1/index.js ADDED
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AeternityBlockExplorer = exports.createAeternityProtocolOptions = exports.createAeternityProtocol = exports.AeternityModule = void 0;
4
+ var AeternityBlockExplorer_1 = require("./block-explorer/AeternityBlockExplorer");
5
+ Object.defineProperty(exports, "AeternityBlockExplorer", { enumerable: true, get: function () { return AeternityBlockExplorer_1.AeternityBlockExplorer; } });
6
+ var AeternityModule_1 = require("./module/AeternityModule");
7
+ Object.defineProperty(exports, "AeternityModule", { enumerable: true, get: function () { return AeternityModule_1.AeternityModule; } });
8
+ var AeternityProtocol_1 = require("./protocol/AeternityProtocol");
9
+ Object.defineProperty(exports, "createAeternityProtocol", { enumerable: true, get: function () { return AeternityProtocol_1.createAeternityProtocol; } });
10
+ Object.defineProperty(exports, "createAeternityProtocolOptions", { enumerable: true, get: function () { return AeternityProtocol_1.createAeternityProtocolOptions; } });
11
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/v1/index.ts"],"names":[],"mappings":";;;AAAA,kFAAgF;AAmBvE,uGAnBA,+CAAsB,OAmBA;AAlB/B,4DAA0D;AAUjD,gGAVA,iCAAe,OAUA;AATxB,kEAAyH;AAa7F,wGAbA,2CAAuB,OAaA;AAAE,+GAbA,kDAA8B,OAaA"}
@@ -0,0 +1,15 @@
1
+ import { MainProtocolSymbols } from '@airgap/coinlib-core';
2
+ import { AirGapBlockExplorer, AirGapModule, AirGapOfflineProtocol, AirGapOnlineProtocol, AirGapV3SerializerCompanion, ProtocolConfiguration } from '@airgap/module-kit';
3
+ declare type SupportedProtocols = MainProtocolSymbols.AE;
4
+ export declare class AeternityModule implements AirGapModule<{
5
+ Protocols: SupportedProtocols;
6
+ }> {
7
+ private readonly networkRegistries;
8
+ readonly supportedProtocols: Record<SupportedProtocols, ProtocolConfiguration>;
9
+ createOfflineProtocol(identifier: SupportedProtocols): Promise<AirGapOfflineProtocol | undefined>;
10
+ createOnlineProtocol(identifier: SupportedProtocols, networkId?: string): Promise<AirGapOnlineProtocol | undefined>;
11
+ createBlockExplorer(identifier: SupportedProtocols, networkId?: string): Promise<AirGapBlockExplorer | undefined>;
12
+ createV3SerializerCompanion(): Promise<AirGapV3SerializerCompanion>;
13
+ private createProtocol;
14
+ }
15
+ export {};
@@ -0,0 +1,107 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __generator = (this && this.__generator) || function (thisArg, body) {
12
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
13
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
14
+ function verb(n) { return function (v) { return step([n, v]); }; }
15
+ function step(op) {
16
+ if (f) throw new TypeError("Generator is already executing.");
17
+ while (_) try {
18
+ 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;
19
+ if (y = 0, t) op = [op[0] & 2, t.value];
20
+ switch (op[0]) {
21
+ case 0: case 1: t = op; break;
22
+ case 4: _.label++; return { value: op[1], done: false };
23
+ case 5: _.label++; y = op[1]; op = [0]; continue;
24
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
25
+ default:
26
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
27
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
28
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
29
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
30
+ if (t[2]) _.ops.pop();
31
+ _.trys.pop(); continue;
32
+ }
33
+ op = body.call(thisArg, _);
34
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
35
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
36
+ }
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.AeternityModule = void 0;
40
+ var coinlib_core_1 = require("@airgap/coinlib-core");
41
+ var errors_1 = require("@airgap/coinlib-core/errors");
42
+ var module_kit_1 = require("@airgap/module-kit");
43
+ var AeternityBlockExplorer_1 = require("../block-explorer/AeternityBlockExplorer");
44
+ var AeternityProtocol_1 = require("../protocol/AeternityProtocol");
45
+ var serializer_companion_1 = require("../serializer/v3/serializer-companion");
46
+ var AeternityModule = /** @class */ (function () {
47
+ function AeternityModule() {
48
+ var _a;
49
+ this.networkRegistries = (_a = {},
50
+ _a[coinlib_core_1.MainProtocolSymbols.AE] = new module_kit_1.ModuleNetworkRegistry({
51
+ supportedNetworks: [AeternityProtocol_1.AETERNITY_MAINNET_PROTOCOL_NETWORK]
52
+ }),
53
+ _a);
54
+ this.supportedProtocols = (0, module_kit_1.createSupportedProtocols)(this.networkRegistries);
55
+ }
56
+ AeternityModule.prototype.createOfflineProtocol = function (identifier) {
57
+ return __awaiter(this, void 0, void 0, function () {
58
+ return __generator(this, function (_a) {
59
+ return [2 /*return*/, this.createProtocol(identifier)];
60
+ });
61
+ });
62
+ };
63
+ AeternityModule.prototype.createOnlineProtocol = function (identifier, networkId) {
64
+ var _a;
65
+ return __awaiter(this, void 0, void 0, function () {
66
+ var network;
67
+ return __generator(this, function (_b) {
68
+ network = (_a = this.networkRegistries[identifier]) === null || _a === void 0 ? void 0 : _a.findNetwork(networkId);
69
+ if (network === undefined) {
70
+ throw new errors_1.ConditionViolationError(coinlib_core_1.Domain.AETERNITY, 'Protocol network not supported.');
71
+ }
72
+ return [2 /*return*/, this.createProtocol(identifier, network)];
73
+ });
74
+ });
75
+ };
76
+ AeternityModule.prototype.createBlockExplorer = function (identifier, networkId) {
77
+ var _a;
78
+ return __awaiter(this, void 0, void 0, function () {
79
+ var network;
80
+ return __generator(this, function (_b) {
81
+ network = (_a = this.networkRegistries[identifier]) === null || _a === void 0 ? void 0 : _a.findNetwork(networkId);
82
+ if ((network === null || network === void 0 ? void 0 : network.type) !== 'mainnet') {
83
+ throw new errors_1.ConditionViolationError(coinlib_core_1.Domain.AETERNITY, 'Block Explorer network not supported.');
84
+ }
85
+ return [2 /*return*/, new AeternityBlockExplorer_1.AeternityBlockExplorer()];
86
+ });
87
+ });
88
+ };
89
+ AeternityModule.prototype.createV3SerializerCompanion = function () {
90
+ return __awaiter(this, void 0, void 0, function () {
91
+ return __generator(this, function (_a) {
92
+ return [2 /*return*/, new serializer_companion_1.AeternityV3SerializerCompanion()];
93
+ });
94
+ });
95
+ };
96
+ AeternityModule.prototype.createProtocol = function (identifier, network) {
97
+ switch (identifier) {
98
+ case coinlib_core_1.MainProtocolSymbols.AE:
99
+ return (0, AeternityProtocol_1.createAeternityProtocol)({ network: network });
100
+ default:
101
+ throw new errors_1.ConditionViolationError(coinlib_core_1.Domain.AETERNITY, "Protocol ".concat(identifier, " not supported."));
102
+ }
103
+ };
104
+ return AeternityModule;
105
+ }());
106
+ exports.AeternityModule = AeternityModule;
107
+ //# sourceMappingURL=AeternityModule.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AeternityModule.js","sourceRoot":"","sources":["../../../src/v1/module/AeternityModule.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,qDAAkE;AAClE,sDAAqE;AACrE,iDAW2B;AAE3B,mFAAiF;AACjF,mEAA2G;AAC3G,8EAAsF;AAItF;IAAA;;QACmB,sBAAiB;YAChC,GAAC,kCAAmB,CAAC,EAAE,IAAG,IAAI,kCAAqB,CAAC;gBAClD,iBAAiB,EAAE,CAAC,sDAAkC,CAAC;aACxD,CAAC;gBACH;QACe,uBAAkB,GAAsD,IAAA,qCAAwB,EAAC,IAAI,CAAC,iBAAiB,CAAC,CAAA;IAoC1I,CAAC;IAlCc,+CAAqB,GAAlC,UAAmC,UAA8B;;;gBAC/D,sBAAO,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,EAAA;;;KACvC;IAEY,8CAAoB,GAAjC,UAAkC,UAA8B,EAAE,SAAkB;;;;;gBAC5E,OAAO,GAAgC,MAAA,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,0CAAE,WAAW,CAAC,SAAS,CAAC,CAAA;gBACvG,IAAI,OAAO,KAAK,SAAS,EAAE;oBACzB,MAAM,IAAI,gCAAuB,CAAC,qBAAM,CAAC,SAAS,EAAE,iCAAiC,CAAC,CAAA;iBACvF;gBAED,sBAAO,IAAI,CAAC,cAAc,CAAC,UAAU,EAAE,OAAO,CAAC,EAAA;;;KAChD;IAEY,6CAAmB,GAAhC,UAAiC,UAA8B,EAAE,SAAkB;;;;;gBAC3E,OAAO,GAAgC,MAAA,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,0CAAE,WAAW,CAAC,SAAS,CAAC,CAAA;gBACvG,IAAI,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,IAAI,MAAK,SAAS,EAAE;oBAC/B,MAAM,IAAI,gCAAuB,CAAC,qBAAM,CAAC,SAAS,EAAE,uCAAuC,CAAC,CAAA;iBAC7F;gBAED,sBAAO,IAAI,+CAAsB,EAAE,EAAA;;;KACpC;IAEY,qDAA2B,GAAxC;;;gBACE,sBAAO,IAAI,qDAA8B,EAAE,EAAA;;;KAC5C;IAEO,wCAAc,GAAtB,UAAuB,UAA8B,EAAE,OAAyB;QAC9E,QAAQ,UAAU,EAAE;YAClB,KAAK,kCAAmB,CAAC,EAAE;gBACzB,OAAO,IAAA,2CAAuB,EAAC,EAAE,OAAO,SAAA,EAAE,CAAC,CAAA;YAC7C;gBACE,MAAM,IAAI,gCAAuB,CAAC,qBAAM,CAAC,SAAS,EAAE,mBAAY,UAAU,oBAAiB,CAAC,CAAA;SAC/F;IACH,CAAC;IACH,sBAAC;AAAD,CAAC,AA1CD,IA0CC;AA1CY,0CAAe"}
package/v1/module.d.ts ADDED
@@ -0,0 +1,3 @@
1
+ import { AirGapModule } from '@airgap/module-kit';
2
+ export * from './index';
3
+ export declare function create(): AirGapModule;
package/v1/module.js ADDED
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
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
+ exports.create = void 0;
18
+ var AeternityModule_1 = require("./module/AeternityModule");
19
+ __exportStar(require("./index"), exports);
20
+ function create() {
21
+ return new AeternityModule_1.AeternityModule();
22
+ }
23
+ exports.create = create;
24
+ //# sourceMappingURL=module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"module.js","sourceRoot":"","sources":["../../src/v1/module.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AACA,4DAA0D;AAE1D,0CAAuB;AAEvB,SAAgB,MAAM;IACpB,OAAO,IAAI,iCAAe,EAAE,CAAA;AAC9B,CAAC;AAFD,wBAEC"}
@@ -0,0 +1,8 @@
1
+ import { Ed25519CryptoClient } from '@airgap/coinlib-core/protocols/Ed25519CryptoClient';
2
+ export declare class AeternityCryptoClient extends Ed25519CryptoClient {
3
+ constructor();
4
+ signMessage(message: string, keypair: {
5
+ privateKey: string;
6
+ }): Promise<string>;
7
+ verifyMessage(message: string, signature: string, publicKey: string): Promise<boolean>;
8
+ }
@@ -0,0 +1,95 @@
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
+ };
53
+ Object.defineProperty(exports, "__esModule", { value: true });
54
+ exports.AeternityCryptoClient = void 0;
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');
62
+ if (messageBuffer.length >= 0xfd) {
63
+ throw new errors_1.InvalidValueError(coinlib_error_1.Domain.AETERNITY, 'message too long');
64
+ }
65
+ return Buffer.concat([Buffer.from([prefix.length]), prefix, Buffer.from([messageBuffer.length]), messageBuffer]);
66
+ };
67
+ var AeternityCryptoClient = /** @class */ (function (_super) {
68
+ __extends(AeternityCryptoClient, _super);
69
+ function AeternityCryptoClient() {
70
+ return _super.call(this) || this;
71
+ }
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));
94
+ exports.AeternityCryptoClient = AeternityCryptoClient;
95
+ //# sourceMappingURL=AeternityCryptoClient.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AeternityCryptoClient.js","sourceRoot":"","sources":["../../../src/v1/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"}
@@ -0,0 +1,52 @@
1
+ import { Address, AirGapProtocol, AirGapTransaction, AirGapTransactionsWithCursor, Amount, Balance, CryptoDerivative, FeeDefaults, KeyPair, ProtocolMetadata, PublicKey, RecursivePartial, SecretKey, Signature, TransactionConfiguration, TransactionDetails } from '@airgap/module-kit';
2
+ import { AeternityCryptoConfiguration } from '../types/crypto';
3
+ import { AeternityProtocolNetwork, AeternityProtocolOptions, AeternityUnits } from '../types/protocol';
4
+ import { AeternitySignedTransaction, AeternityTransactionCursor, AeternityUnsignedTransaction } from '../types/transaction';
5
+ export interface AeternityProtocol extends AirGapProtocol<{
6
+ AddressResult: Address;
7
+ ProtocolNetwork: AeternityProtocolNetwork;
8
+ CryptoConfiguration: AeternityCryptoConfiguration;
9
+ SignedTransaction: AeternitySignedTransaction;
10
+ TransactionCursor: AeternityTransactionCursor;
11
+ Units: AeternityUnits;
12
+ FeeEstimation: FeeDefaults<AeternityUnits>;
13
+ UnsignedTransaction: AeternityUnsignedTransaction;
14
+ }, 'Crypto', 'FetchDataForAddress'> {
15
+ convertTransactionToBase58(preparedTx: AeternityUnsignedTransaction): Promise<AeternityUnsignedTransaction>;
16
+ }
17
+ export declare class AeternityProtocolImpl implements AeternityProtocol {
18
+ private readonly cryptoClient;
19
+ private readonly options;
20
+ constructor(options?: RecursivePartial<AeternityProtocolOptions>);
21
+ private readonly units;
22
+ private readonly feeDefaults;
23
+ private readonly metadata;
24
+ getMetadata(): Promise<ProtocolMetadata<AeternityUnits>>;
25
+ getAddressFromPublicKey(publicKey: PublicKey): Promise<string>;
26
+ getDetailsFromTransaction(transaction: AeternitySignedTransaction | AeternityUnsignedTransaction, _publicKey: PublicKey): Promise<AirGapTransaction<AeternityUnits>[]>;
27
+ private getDetailsFromEncodedTransaction;
28
+ verifyMessageWithPublicKey(message: string, signature: Signature, publicKey: PublicKey): Promise<boolean>;
29
+ encryptAsymmetricWithPublicKey(payload: string, publicKey: PublicKey): Promise<string>;
30
+ private readonly cryptoConfiguration;
31
+ getCryptoConfiguration(): Promise<AeternityCryptoConfiguration>;
32
+ getKeyPairFromDerivative(derivative: CryptoDerivative): Promise<KeyPair>;
33
+ signTransactionWithSecretKey(transaction: AeternityUnsignedTransaction, secretKey: SecretKey): Promise<AeternitySignedTransaction>;
34
+ signMessageWithKeyPair(message: string, keyPair: KeyPair): Promise<Signature>;
35
+ decryptAsymmetricWithKeyPair(payload: string, keyPair: KeyPair): Promise<string>;
36
+ encryptAESWithSecretKey(payload: string, secretKey: SecretKey): Promise<string>;
37
+ decryptAESWithSecretKey(payload: string, secretKey: SecretKey): Promise<string>;
38
+ getNetwork(): Promise<AeternityProtocolNetwork>;
39
+ getTransactionsForPublicKey(publicKey: PublicKey, limit: number, cursor?: AeternityTransactionCursor): Promise<AirGapTransactionsWithCursor<AeternityTransactionCursor, AeternityUnits>>;
40
+ getTransactionsForAddress(address: string, limit: number, cursor?: AeternityTransactionCursor): Promise<AirGapTransactionsWithCursor<AeternityTransactionCursor, AeternityUnits>>;
41
+ getBalanceOfPublicKey(publicKey: PublicKey): Promise<Balance<AeternityUnits>>;
42
+ getBalanceOfAddress(address: string): Promise<Balance<AeternityUnits>>;
43
+ getTransactionMaxAmountWithPublicKey(publicKey: PublicKey, to: string[], configuration?: TransactionConfiguration<AeternityUnits>): Promise<Amount<AeternityUnits>>;
44
+ getTransactionFeeWithPublicKey(_publicKey: PublicKey, _details: TransactionDetails<AeternityUnits>[]): Promise<FeeDefaults<AeternityUnits>>;
45
+ prepareTransactionWithPublicKey(publicKey: PublicKey, details: TransactionDetails<AeternityUnits>[], configuration?: TransactionConfiguration<AeternityUnits>): Promise<AeternityUnsignedTransaction>;
46
+ private networkId;
47
+ broadcastTransaction(transaction: AeternitySignedTransaction): Promise<string>;
48
+ convertTransactionToBase58(preparedTx: AeternityUnsignedTransaction): Promise<AeternityUnsignedTransaction>;
49
+ }
50
+ export declare function createAeternityProtocol(options?: RecursivePartial<AeternityProtocolOptions>): AeternityProtocol;
51
+ export declare const AETERNITY_MAINNET_PROTOCOL_NETWORK: AeternityProtocolNetwork;
52
+ export declare function createAeternityProtocolOptions(network?: Partial<AeternityProtocolNetwork>): AeternityProtocolOptions;