@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
package/index.d.ts ADDED
@@ -0,0 +1 @@
1
+ export * from './v0';
package/index.js ADDED
@@ -0,0 +1,18 @@
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
+ __exportStar(require("./v0"), exports);
18
+ //# sourceMappingURL=index.js.map
package/index.js.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,uCAAoB"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@airgap/aeternity",
3
- "version": "0.13.11-beta.1",
3
+ "version": "0.13.11-beta.3",
4
4
  "description": "The @airgap/aeternity is an Aeternity implementation of the ICoinProtocol interface from @airgap/coinlib-core.",
5
5
  "keywords": [
6
6
  "airgap",
@@ -17,10 +17,6 @@
17
17
  "publishConfig": {
18
18
  "access": "public"
19
19
  },
20
- "main": "dist/index.js",
21
- "files": [
22
- "dist"
23
- ],
24
20
  "scripts": {
25
21
  "build": "rm -rf ./dist && tsc && node scripts/copy-files-after-build.js",
26
22
  "build-scripts": "tsc scripts/*.ts",
package/v0/index.d.ts ADDED
@@ -0,0 +1,8 @@
1
+ import { AeternityAddress } from './protocol/AeternityAddress';
2
+ import { AeternityCryptoClient } from './protocol/AeternityCryptoClient';
3
+ import { AeternityProtocol } from './protocol/AeternityProtocol';
4
+ import { AeternalBlockExplorer, AeternityProtocolNetwork, AeternityProtocolOptions } from './protocol/AeternityProtocolOptions';
5
+ import { SignedAeternityTransaction } from './types/signed-transaction-aeternity';
6
+ import { RawAeternityTransaction } from './types/transaction-aeternity';
7
+ import { UnsignedAeternityTransaction } from './types/unsigned-transaction-aeternity';
8
+ export { AeternityProtocol, AeternityCryptoClient, AeternityProtocolOptions, AeternalBlockExplorer, AeternityProtocolNetwork, AeternityAddress, RawAeternityTransaction, UnsignedAeternityTransaction, SignedAeternityTransaction };
package/v0/index.js ADDED
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AeternityAddress = exports.AeternityProtocolNetwork = exports.AeternalBlockExplorer = exports.AeternityProtocolOptions = exports.AeternityCryptoClient = exports.AeternityProtocol = void 0;
4
+ var coinlib_core_1 = require("@airgap/coinlib-core");
5
+ var serializer_1 = require("@airgap/serializer");
6
+ var AeternityAddress_1 = require("./protocol/AeternityAddress");
7
+ Object.defineProperty(exports, "AeternityAddress", { enumerable: true, get: function () { return AeternityAddress_1.AeternityAddress; } });
8
+ var AeternityCryptoClient_1 = require("./protocol/AeternityCryptoClient");
9
+ Object.defineProperty(exports, "AeternityCryptoClient", { enumerable: true, get: function () { return AeternityCryptoClient_1.AeternityCryptoClient; } });
10
+ var AeternityProtocol_1 = require("./protocol/AeternityProtocol");
11
+ Object.defineProperty(exports, "AeternityProtocol", { enumerable: true, get: function () { return AeternityProtocol_1.AeternityProtocol; } });
12
+ var AeternityProtocolOptions_1 = require("./protocol/AeternityProtocolOptions");
13
+ Object.defineProperty(exports, "AeternalBlockExplorer", { enumerable: true, get: function () { return AeternityProtocolOptions_1.AeternalBlockExplorer; } });
14
+ Object.defineProperty(exports, "AeternityProtocolNetwork", { enumerable: true, get: function () { return AeternityProtocolOptions_1.AeternityProtocolNetwork; } });
15
+ Object.defineProperty(exports, "AeternityProtocolOptions", { enumerable: true, get: function () { return AeternityProtocolOptions_1.AeternityProtocolOptions; } });
16
+ var transaction_validator_1 = require("./serializer/validators/transaction-validator");
17
+ // Serializer
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
+ serializer_1.Serializer.addSchema(serializer_1.IACMessageType.TransactionSignResponse, { schema: require('./serializer/schemas/v2/transaction-sign-response-aeternity.json') }, coinlib_core_1.MainProtocolSymbols.AE);
20
+ serializer_1.SerializerV3.addSchema(serializer_1.IACMessageType.TransactionSignRequest, { schema: require('./serializer/schemas/v3/transaction-sign-request-aeternity.json') }, coinlib_core_1.MainProtocolSymbols.AE);
21
+ serializer_1.SerializerV3.addSchema(serializer_1.IACMessageType.TransactionSignResponse, { schema: require('./serializer/schemas/v3/transaction-sign-response-aeternity.json') }, coinlib_core_1.MainProtocolSymbols.AE);
22
+ serializer_1.Serializer.addValidator(coinlib_core_1.MainProtocolSymbols.AE, new transaction_validator_1.AeternityTransactionValidatorFactoryV2());
23
+ serializer_1.SerializerV3.addValidator(coinlib_core_1.MainProtocolSymbols.AE, new transaction_validator_1.AeternityTransactionValidatorFactory());
24
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
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"}
@@ -0,0 +1,7 @@
1
+ import { IAirGapAddress } from '@airgap/coinlib-core/interfaces/IAirGapAddress';
2
+ export declare class AeternityAddress implements IAirGapAddress {
3
+ private readonly value;
4
+ private constructor();
5
+ static from(publicKey: string): AeternityAddress;
6
+ asString(): string;
7
+ }
@@ -0,0 +1,42 @@
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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
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
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.AeternityAddress = void 0;
27
+ var bs58check = __importStar(require("@airgap/coinlib-core/dependencies/src/bs58check-2.1.2/index"));
28
+ var AeternityAddress = /** @class */ (function () {
29
+ function AeternityAddress(value) {
30
+ this.value = value;
31
+ }
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 () {
37
+ return this.value;
38
+ };
39
+ return AeternityAddress;
40
+ }());
41
+ exports.AeternityAddress = AeternityAddress;
42
+ //# sourceMappingURL=AeternityAddress.js.map
@@ -0,0 +1 @@
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"}
@@ -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/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"}
@@ -0,0 +1,102 @@
1
+ import { IAirGapSignedTransaction } from '@airgap/coinlib-core/interfaces/IAirGapSignedTransaction';
2
+ import { AirGapTransactionStatus, IAirGapTransaction } from '@airgap/coinlib-core/interfaces/IAirGapTransaction';
3
+ import { CurrencyUnit, FeeDefaults, ICoinProtocol } from '@airgap/coinlib-core/protocols/ICoinProtocol';
4
+ import { ICoinSubProtocol } from '@airgap/coinlib-core/protocols/ICoinSubProtocol';
5
+ import { NonExtendedProtocol } from '@airgap/coinlib-core/protocols/NonExtendedProtocol';
6
+ import { ProtocolSymbols } from '@airgap/coinlib-core/utils/ProtocolSymbols';
7
+ import { SignedAeternityTransaction } from '../types/signed-transaction-aeternity';
8
+ import { RawAeternityTransaction } from '../types/transaction-aeternity';
9
+ import { UnsignedAeternityTransaction } from '../types/unsigned-transaction-aeternity';
10
+ import { AeternityCryptoClient } from './AeternityCryptoClient';
11
+ import { AeternityProtocolOptions } from './AeternityProtocolOptions';
12
+ import { AeternityAddressCursor, AeternityAddressResult, AeternityTransactionCursor, AeternityTransactionResult } from './AeternityTypes';
13
+ export declare class AeternityProtocol extends NonExtendedProtocol implements ICoinProtocol {
14
+ readonly options: AeternityProtocolOptions;
15
+ symbol: string;
16
+ name: string;
17
+ marketSymbol: string;
18
+ feeSymbol: string;
19
+ decimals: number;
20
+ feeDecimals: number;
21
+ identifier: ProtocolSymbols;
22
+ feeDefaults: FeeDefaults;
23
+ units: CurrencyUnit[];
24
+ supportsHD: boolean;
25
+ standardDerivationPath: string;
26
+ addressIsCaseSensitive: boolean;
27
+ addressValidationPattern: string;
28
+ addressPlaceholder: string;
29
+ defaultNetworkId: string;
30
+ private readonly feesURL;
31
+ readonly cryptoClient: AeternityCryptoClient;
32
+ constructor(options?: AeternityProtocolOptions);
33
+ getSymbol(): Promise<string>;
34
+ getName(): Promise<string>;
35
+ getMarketSymbol(): Promise<string>;
36
+ getFeeSymbol(): Promise<string>;
37
+ getDecimals(): Promise<number>;
38
+ getFeeDecimals(): Promise<number>;
39
+ getIdentifier(): Promise<ProtocolSymbols>;
40
+ getFeeDefaults(): Promise<FeeDefaults>;
41
+ getUnits(): Promise<CurrencyUnit[]>;
42
+ getSupportsHD(): Promise<boolean>;
43
+ getStandardDerivationPath(): Promise<string>;
44
+ getAddressIsCaseSensitive(): Promise<boolean>;
45
+ getAddressValidationPattern(): Promise<string>;
46
+ getAddressPlaceholder(): Promise<string>;
47
+ getOptions(): Promise<AeternityProtocolOptions>;
48
+ getBlockExplorerLinkForAddress(address: string): Promise<string>;
49
+ getBlockExplorerLinkForTxId(txId: string): Promise<string>;
50
+ getPublicKeyFromMnemonic(mnemonic: string, derivationPath: string, password?: string): Promise<string>;
51
+ getPrivateKeyFromMnemonic(mnemonic: string, derivationPath: string, password?: string): Promise<string>;
52
+ /**
53
+ * Returns the PublicKey as String, derived from a supplied hex-string
54
+ * @param secret HEX-Secret from BIP39
55
+ * @param derivationPath DerivationPath for Key
56
+ */
57
+ getPublicKeyFromHexSecret(secret: string, derivationPath: string): Promise<string>;
58
+ /**
59
+ * Returns the PrivateKey as Buffer, derived from a supplied hex-string
60
+ * @param secret HEX-Secret from BIP39
61
+ * @param derivationPath DerivationPath for Key
62
+ */
63
+ getPrivateKeyFromHexSecret(secret: string, derivationPath: string): Promise<string>;
64
+ getAddressFromPublicKey(publicKey: string, cursor?: AeternityAddressCursor): Promise<AeternityAddressResult>;
65
+ getAddressesFromPublicKey(publicKey: string, cursor?: AeternityAddressCursor): Promise<AeternityAddressResult[]>;
66
+ getTransactionsFromPublicKey(publicKey: string, limit: number, cursor?: AeternityTransactionCursor): Promise<AeternityTransactionResult>;
67
+ getTransactionsFromAddresses(addresses: string[], limit: number, cursor?: AeternityTransactionCursor): Promise<AeternityTransactionResult>;
68
+ protected getPageNumber(limit: number, offset: number): number;
69
+ signWithPrivateKey(privateKey: string, transaction: RawAeternityTransaction): Promise<IAirGapSignedTransaction>;
70
+ private decodeTx;
71
+ getTransactionDetails(unsignedTx: UnsignedAeternityTransaction): Promise<IAirGapTransaction[]>;
72
+ getTransactionDetailsFromSigned(signedTx: SignedAeternityTransaction): Promise<IAirGapTransaction[]>;
73
+ getBalanceOfAddresses(addresses: string[]): Promise<string>;
74
+ getBalanceOfPublicKey(publicKey: string): Promise<string>;
75
+ getBalanceOfPublicKeyForSubProtocols(publicKey: string, subProtocols: ICoinSubProtocol[]): Promise<string[]>;
76
+ getAvailableBalanceOfAddresses(addresses: string[]): Promise<string>;
77
+ estimateMaxTransactionValueFromPublicKey(publicKey: string, recipients: string[], fee?: string): Promise<string>;
78
+ estimateFeeDefaultsFromPublicKey(publicKey: string, recipients: string[], values: string[], data?: any): Promise<FeeDefaults>;
79
+ prepareTransactionFromPublicKey(publicKey: string, recipients: string[], values: string[], fee: string, data?: {
80
+ payload?: string;
81
+ }): Promise<RawAeternityTransaction>;
82
+ /**
83
+ * This is a function that we only use to fix incompatibilitis with old vault versions that are unable to understand b64 encoded Txs.
84
+ *
85
+ * @deprecated
86
+ * @param preparedTx
87
+ */
88
+ convertTxToBase58(preparedTx: RawAeternityTransaction): RawAeternityTransaction;
89
+ broadcastTransaction(rawTransaction: string): Promise<string>;
90
+ signMessage(message: string, keypair: {
91
+ privateKey: string;
92
+ }): Promise<string>;
93
+ verifyMessage(message: string, signature: string, publicKey: string): Promise<boolean>;
94
+ encryptAsymmetric(message: string, publicKey: string): Promise<string>;
95
+ decryptAsymmetric(message: string, keypair: {
96
+ publicKey: string;
97
+ privateKey: string;
98
+ }): Promise<string>;
99
+ encryptAES(message: string, privateKey: string): Promise<string>;
100
+ decryptAES(message: string, privateKey: string): Promise<string>;
101
+ getTransactionStatuses(transactionHashes: string[]): Promise<AirGapTransactionStatus[]>;
102
+ }