@ledgerhq/coin-hedera 1.10.1 → 1.11.0-nightly.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintrc.js +1 -0
- package/.turbo/turbo-build.log +1 -1
- package/CHANGELOG.md +37 -12
- package/lib/api/mirror.d.ts +3 -20
- package/lib/api/mirror.d.ts.map +1 -1
- package/lib/api/mirror.js +32 -90
- package/lib/api/mirror.js.map +1 -1
- package/lib/api/mirror.test.js +59 -4
- package/lib/api/mirror.test.js.map +1 -1
- package/lib/api/network.d.ts +3 -3
- package/lib/api/network.d.ts.map +1 -1
- package/lib/api/network.js +46 -3
- package/lib/api/network.js.map +1 -1
- package/lib/api/types.d.ts +44 -0
- package/lib/api/types.d.ts.map +1 -0
- package/lib/api/types.js +3 -0
- package/lib/api/types.js.map +1 -0
- package/lib/api/utils.d.ts +8 -0
- package/lib/api/utils.d.ts.map +1 -0
- package/lib/api/utils.js +132 -0
- package/lib/api/utils.js.map +1 -0
- package/lib/bridge/broadcast.d.ts.map +1 -1
- package/lib/bridge/broadcast.js +2 -0
- package/lib/bridge/broadcast.js.map +1 -1
- package/lib/bridge/buildOptimisticOperation.d.ts +2 -2
- package/lib/bridge/buildOptimisticOperation.d.ts.map +1 -1
- package/lib/bridge/buildOptimisticOperation.integration.test.d.ts +2 -0
- package/lib/bridge/buildOptimisticOperation.integration.test.d.ts.map +1 -0
- package/lib/bridge/buildOptimisticOperation.integration.test.js +82 -0
- package/lib/bridge/buildOptimisticOperation.integration.test.js.map +1 -0
- package/lib/bridge/buildOptimisticOperation.js +87 -5
- package/lib/bridge/buildOptimisticOperation.js.map +1 -1
- package/lib/bridge/estimateMaxSpendable.d.ts.map +1 -1
- package/lib/bridge/estimateMaxSpendable.js +8 -2
- package/lib/bridge/estimateMaxSpendable.js.map +1 -1
- package/lib/bridge/getTransactionStatus.d.ts +3 -3
- package/lib/bridge/getTransactionStatus.d.ts.map +1 -1
- package/lib/bridge/getTransactionStatus.js +116 -23
- package/lib/bridge/getTransactionStatus.js.map +1 -1
- package/lib/bridge/getTransactionStatus.test.d.ts +2 -0
- package/lib/bridge/getTransactionStatus.test.d.ts.map +1 -0
- package/lib/bridge/getTransactionStatus.test.js +176 -0
- package/lib/bridge/getTransactionStatus.test.js.map +1 -0
- package/lib/bridge/index.d.ts +4 -4
- package/lib/bridge/index.d.ts.map +1 -1
- package/lib/bridge/index.js +9 -6
- package/lib/bridge/index.js.map +1 -1
- package/lib/bridge/js-estimateMaxSpendable.integration.test.js +28 -44
- package/lib/bridge/js-estimateMaxSpendable.integration.test.js.map +1 -1
- package/lib/bridge/js-transaction.test.js +10 -49
- package/lib/bridge/js-transaction.test.js.map +1 -1
- package/lib/bridge/prepareTransaction.d.ts +0 -1
- package/lib/bridge/prepareTransaction.d.ts.map +1 -1
- package/lib/bridge/prepareTransaction.js +0 -1
- package/lib/bridge/prepareTransaction.js.map +1 -1
- package/lib/bridge/serialization.d.ts +7 -0
- package/lib/bridge/serialization.d.ts.map +1 -0
- package/lib/bridge/serialization.js +36 -0
- package/lib/bridge/serialization.js.map +1 -0
- package/lib/bridge/serialization.test.d.ts +2 -0
- package/lib/bridge/serialization.test.d.ts.map +1 -0
- package/lib/bridge/serialization.test.js +27 -0
- package/lib/bridge/serialization.test.js.map +1 -0
- package/lib/bridge/synchronisation.d.ts +3 -3
- package/lib/bridge/synchronisation.d.ts.map +1 -1
- package/lib/bridge/synchronisation.js +37 -15
- package/lib/bridge/synchronisation.js.map +1 -1
- package/lib/bridge/transaction.test.js +18 -59
- package/lib/bridge/transaction.test.js.map +1 -1
- package/lib/bridge/utils.d.ts +22 -8
- package/lib/bridge/utils.d.ts.map +1 -1
- package/lib/bridge/utils.integration.test.js +415 -73
- package/lib/bridge/utils.integration.test.js.map +1 -1
- package/lib/bridge/utils.js +300 -15
- package/lib/bridge/utils.js.map +1 -1
- package/lib/constants.d.ts +32 -0
- package/lib/constants.d.ts.map +1 -0
- package/lib/constants.js +37 -0
- package/lib/constants.js.map +1 -0
- package/lib/deviceTransactionConfig.d.ts.map +1 -1
- package/lib/deviceTransactionConfig.js +17 -15
- package/lib/deviceTransactionConfig.js.map +1 -1
- package/lib/logic.d.ts +9 -3
- package/lib/logic.d.ts.map +1 -1
- package/lib/logic.js +31 -3
- package/lib/logic.js.map +1 -1
- package/lib/logic.test.js +103 -50
- package/lib/logic.test.js.map +1 -1
- package/lib/test/fixtures/account.fixture.d.ts +19 -0
- package/lib/test/fixtures/account.fixture.d.ts.map +1 -0
- package/lib/test/fixtures/account.fixture.js +116 -0
- package/lib/test/fixtures/account.fixture.js.map +1 -0
- package/lib/test/fixtures/currency.fixture.d.ts +5 -0
- package/lib/test/fixtures/currency.fixture.d.ts.map +1 -0
- package/lib/test/fixtures/currency.fixture.js +67 -0
- package/lib/test/fixtures/currency.fixture.js.map +1 -0
- package/lib/test/fixtures/mirror.fixture.d.ts +3 -0
- package/lib/test/fixtures/mirror.fixture.d.ts.map +1 -0
- package/lib/test/fixtures/mirror.fixture.js +17 -0
- package/lib/test/fixtures/mirror.fixture.js.map +1 -0
- package/lib/test/fixtures/operation.fixture.d.ts +3 -0
- package/lib/test/fixtures/operation.fixture.d.ts.map +1 -0
- package/lib/test/fixtures/operation.fixture.js +26 -0
- package/lib/test/fixtures/operation.fixture.js.map +1 -0
- package/lib/test/fixtures/transaction.fixture.d.ts +4 -0
- package/lib/test/fixtures/transaction.fixture.d.ts.map +1 -0
- package/lib/test/fixtures/transaction.fixture.js +28 -0
- package/lib/test/fixtures/transaction.fixture.js.map +1 -0
- package/lib/types/bridge.d.ts +25 -1
- package/lib/types/bridge.d.ts.map +1 -1
- package/lib-es/api/mirror.d.ts +3 -20
- package/lib-es/api/mirror.d.ts.map +1 -1
- package/lib-es/api/mirror.js +29 -88
- package/lib-es/api/mirror.js.map +1 -1
- package/lib-es/api/mirror.test.js +60 -5
- package/lib-es/api/mirror.test.js.map +1 -1
- package/lib-es/api/network.d.ts +3 -3
- package/lib-es/api/network.d.ts.map +1 -1
- package/lib-es/api/network.js +44 -4
- package/lib-es/api/network.js.map +1 -1
- package/lib-es/api/types.d.ts +44 -0
- package/lib-es/api/types.d.ts.map +1 -0
- package/lib-es/api/types.js +2 -0
- package/lib-es/api/types.js.map +1 -0
- package/lib-es/api/utils.d.ts +8 -0
- package/lib-es/api/utils.d.ts.map +1 -0
- package/lib-es/api/utils.js +124 -0
- package/lib-es/api/utils.js.map +1 -0
- package/lib-es/bridge/broadcast.d.ts.map +1 -1
- package/lib-es/bridge/broadcast.js +2 -0
- package/lib-es/bridge/broadcast.js.map +1 -1
- package/lib-es/bridge/buildOptimisticOperation.d.ts +2 -2
- package/lib-es/bridge/buildOptimisticOperation.d.ts.map +1 -1
- package/lib-es/bridge/buildOptimisticOperation.integration.test.d.ts +2 -0
- package/lib-es/bridge/buildOptimisticOperation.integration.test.d.ts.map +1 -0
- package/lib-es/bridge/buildOptimisticOperation.integration.test.js +77 -0
- package/lib-es/bridge/buildOptimisticOperation.integration.test.js.map +1 -0
- package/lib-es/bridge/buildOptimisticOperation.js +84 -5
- package/lib-es/bridge/buildOptimisticOperation.js.map +1 -1
- package/lib-es/bridge/estimateMaxSpendable.d.ts.map +1 -1
- package/lib-es/bridge/estimateMaxSpendable.js +8 -2
- package/lib-es/bridge/estimateMaxSpendable.js.map +1 -1
- package/lib-es/bridge/getTransactionStatus.d.ts +3 -3
- package/lib-es/bridge/getTransactionStatus.d.ts.map +1 -1
- package/lib-es/bridge/getTransactionStatus.js +114 -24
- package/lib-es/bridge/getTransactionStatus.js.map +1 -1
- package/lib-es/bridge/getTransactionStatus.test.d.ts +2 -0
- package/lib-es/bridge/getTransactionStatus.test.d.ts.map +1 -0
- package/lib-es/bridge/getTransactionStatus.test.js +148 -0
- package/lib-es/bridge/getTransactionStatus.test.js.map +1 -0
- package/lib-es/bridge/index.d.ts +4 -4
- package/lib-es/bridge/index.d.ts.map +1 -1
- package/lib-es/bridge/index.js +9 -6
- package/lib-es/bridge/index.js.map +1 -1
- package/lib-es/bridge/js-estimateMaxSpendable.integration.test.js +28 -44
- package/lib-es/bridge/js-estimateMaxSpendable.integration.test.js.map +1 -1
- package/lib-es/bridge/js-transaction.test.js +10 -49
- package/lib-es/bridge/js-transaction.test.js.map +1 -1
- package/lib-es/bridge/prepareTransaction.d.ts +0 -1
- package/lib-es/bridge/prepareTransaction.d.ts.map +1 -1
- package/lib-es/bridge/prepareTransaction.js +0 -1
- package/lib-es/bridge/prepareTransaction.js.map +1 -1
- package/lib-es/bridge/serialization.d.ts +7 -0
- package/lib-es/bridge/serialization.d.ts.map +1 -0
- package/lib-es/bridge/serialization.js +29 -0
- package/lib-es/bridge/serialization.js.map +1 -0
- package/lib-es/bridge/serialization.test.d.ts +2 -0
- package/lib-es/bridge/serialization.test.d.ts.map +1 -0
- package/lib-es/bridge/serialization.test.js +25 -0
- package/lib-es/bridge/serialization.test.js.map +1 -0
- package/lib-es/bridge/synchronisation.d.ts +3 -3
- package/lib-es/bridge/synchronisation.d.ts.map +1 -1
- package/lib-es/bridge/synchronisation.js +39 -17
- package/lib-es/bridge/synchronisation.js.map +1 -1
- package/lib-es/bridge/transaction.test.js +18 -59
- package/lib-es/bridge/transaction.test.js.map +1 -1
- package/lib-es/bridge/utils.d.ts +22 -8
- package/lib-es/bridge/utils.d.ts.map +1 -1
- package/lib-es/bridge/utils.integration.test.js +416 -74
- package/lib-es/bridge/utils.integration.test.js.map +1 -1
- package/lib-es/bridge/utils.js +295 -15
- package/lib-es/bridge/utils.js.map +1 -1
- package/lib-es/constants.d.ts +32 -0
- package/lib-es/constants.d.ts.map +1 -0
- package/lib-es/constants.js +34 -0
- package/lib-es/constants.js.map +1 -0
- package/lib-es/deviceTransactionConfig.d.ts.map +1 -1
- package/lib-es/deviceTransactionConfig.js +17 -15
- package/lib-es/deviceTransactionConfig.js.map +1 -1
- package/lib-es/logic.d.ts +9 -3
- package/lib-es/logic.d.ts.map +1 -1
- package/lib-es/logic.js +26 -3
- package/lib-es/logic.js.map +1 -1
- package/lib-es/logic.test.js +104 -51
- package/lib-es/logic.test.js.map +1 -1
- package/lib-es/test/fixtures/account.fixture.d.ts +19 -0
- package/lib-es/test/fixtures/account.fixture.d.ts.map +1 -0
- package/lib-es/test/fixtures/account.fixture.js +107 -0
- package/lib-es/test/fixtures/account.fixture.js.map +1 -0
- package/lib-es/test/fixtures/currency.fixture.d.ts +5 -0
- package/lib-es/test/fixtures/currency.fixture.d.ts.map +1 -0
- package/lib-es/test/fixtures/currency.fixture.js +58 -0
- package/lib-es/test/fixtures/currency.fixture.js.map +1 -0
- package/lib-es/test/fixtures/mirror.fixture.d.ts +3 -0
- package/lib-es/test/fixtures/mirror.fixture.d.ts.map +1 -0
- package/lib-es/test/fixtures/mirror.fixture.js +13 -0
- package/lib-es/test/fixtures/mirror.fixture.js.map +1 -0
- package/lib-es/test/fixtures/operation.fixture.d.ts +3 -0
- package/lib-es/test/fixtures/operation.fixture.d.ts.map +1 -0
- package/lib-es/test/fixtures/operation.fixture.js +19 -0
- package/lib-es/test/fixtures/operation.fixture.js.map +1 -0
- package/lib-es/test/fixtures/transaction.fixture.d.ts +4 -0
- package/lib-es/test/fixtures/transaction.fixture.d.ts.map +1 -0
- package/lib-es/test/fixtures/transaction.fixture.js +20 -0
- package/lib-es/test/fixtures/transaction.fixture.js.map +1 -0
- package/lib-es/types/bridge.d.ts +25 -1
- package/lib-es/types/bridge.d.ts.map +1 -1
- package/package.json +12 -10
- package/src/api/mirror.test.ts +79 -5
- package/src/api/mirror.ts +30 -111
- package/src/api/network.ts +71 -4
- package/src/api/types.ts +48 -0
- package/src/api/utils.ts +150 -0
- package/src/bridge/broadcast.ts +2 -0
- package/src/bridge/buildOptimisticOperation.integration.test.ts +88 -0
- package/src/bridge/buildOptimisticOperation.ts +118 -7
- package/src/bridge/estimateMaxSpendable.ts +8 -2
- package/src/bridge/getTransactionStatus.test.ts +200 -0
- package/src/bridge/getTransactionStatus.ts +166 -32
- package/src/bridge/index.ts +13 -10
- package/src/bridge/js-estimateMaxSpendable.integration.test.ts +37 -46
- package/src/bridge/js-transaction.test.ts +13 -54
- package/src/bridge/prepareTransaction.ts +1 -2
- package/src/bridge/serialization.test.ts +39 -0
- package/src/bridge/serialization.ts +43 -0
- package/src/bridge/synchronisation.ts +65 -27
- package/src/bridge/transaction.test.ts +22 -64
- package/src/bridge/utils.integration.test.ts +525 -76
- package/src/bridge/utils.ts +423 -24
- package/src/constants.ts +35 -0
- package/src/deviceTransactionConfig.ts +16 -15
- package/src/logic.test.ts +147 -57
- package/src/logic.ts +58 -7
- package/src/test/fixtures/account.fixture.ts +123 -0
- package/src/test/fixtures/currency.fixture.ts +66 -0
- package/src/test/fixtures/mirror.fixture.ts +14 -0
- package/src/test/fixtures/operation.fixture.ts +20 -0
- package/src/test/fixtures/transaction.fixture.ts +22 -0
- package/src/types/bridge.ts +33 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getTransactionStatus.test.d.ts","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,176 @@
|
|
|
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
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
30
|
+
const errors_1 = require("@ledgerhq/errors");
|
|
31
|
+
const account_fixture_1 = require("../test/fixtures/account.fixture");
|
|
32
|
+
const currency_fixture_1 = require("../test/fixtures/currency.fixture");
|
|
33
|
+
const transaction_fixture_1 = require("../test/fixtures/transaction.fixture");
|
|
34
|
+
const getTransactionStatus_1 = require("./getTransactionStatus");
|
|
35
|
+
const utils = __importStar(require("./utils"));
|
|
36
|
+
const constants_1 = require("../constants");
|
|
37
|
+
describe("getTransactionStatus", () => {
|
|
38
|
+
const mockedEstimatedFee = new bignumber_js_1.default(1);
|
|
39
|
+
const mockedUsdRate = new bignumber_js_1.default(1);
|
|
40
|
+
const validRecipientAddress = "0.0.1234567";
|
|
41
|
+
const invalidRecipientAddress = "invalid_address";
|
|
42
|
+
beforeEach(() => {
|
|
43
|
+
jest.clearAllMocks();
|
|
44
|
+
jest.spyOn(utils, "getCurrencyToUSDRate").mockResolvedValueOnce(mockedUsdRate);
|
|
45
|
+
jest.spyOn(utils, "getEstimatedFees").mockResolvedValueOnce(mockedEstimatedFee);
|
|
46
|
+
});
|
|
47
|
+
test("coin transfer with valid recipient and sufficient balance completes successfully", async () => {
|
|
48
|
+
const mockedAccount = (0, account_fixture_1.getMockedAccount)({ balance: new bignumber_js_1.default(1000) });
|
|
49
|
+
const mockedTransaction = (0, transaction_fixture_1.getMockedTransaction)({
|
|
50
|
+
recipient: validRecipientAddress,
|
|
51
|
+
amount: new bignumber_js_1.default(100),
|
|
52
|
+
});
|
|
53
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockedAccount, mockedTransaction);
|
|
54
|
+
expect(result.errors).toEqual({});
|
|
55
|
+
expect(result.warnings).toEqual({});
|
|
56
|
+
expect(result.amount).toEqual(new bignumber_js_1.default(100));
|
|
57
|
+
expect(result.totalSpent.isGreaterThan(100)).toBe(true);
|
|
58
|
+
});
|
|
59
|
+
test("token transfer with valid recipient and sufficient balance completes successfully", async () => {
|
|
60
|
+
jest.spyOn(utils, "checkAccountTokenAssociationStatus").mockResolvedValueOnce(true);
|
|
61
|
+
const tokenCurrency = (0, currency_fixture_1.getMockedTokenCurrency)();
|
|
62
|
+
const tokenAccount = (0, account_fixture_1.getMockedTokenAccount)(tokenCurrency, { balance: new bignumber_js_1.default(500) });
|
|
63
|
+
const account = (0, account_fixture_1.getMockedAccount)({ balance: new bignumber_js_1.default(1000), subAccounts: [tokenAccount] });
|
|
64
|
+
const transaction = (0, transaction_fixture_1.getMockedTransaction)({
|
|
65
|
+
subAccountId: tokenAccount.id,
|
|
66
|
+
recipient: validRecipientAddress,
|
|
67
|
+
amount: new bignumber_js_1.default(200),
|
|
68
|
+
});
|
|
69
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(account, transaction);
|
|
70
|
+
expect(result.errors).toEqual({});
|
|
71
|
+
expect(result.warnings).toEqual({});
|
|
72
|
+
expect(result.amount).toEqual(new bignumber_js_1.default(200));
|
|
73
|
+
});
|
|
74
|
+
test("token associate transaction with sufficient USD worth completes successfully", async () => {
|
|
75
|
+
const mockedTokenCurrency = (0, currency_fixture_1.getMockedTokenCurrency)();
|
|
76
|
+
const mockedAccount = (0, account_fixture_1.getMockedAccount)();
|
|
77
|
+
const mockedTransaction = (0, transaction_fixture_1.getMockedTransaction)({
|
|
78
|
+
properties: {
|
|
79
|
+
name: constants_1.HEDERA_TRANSACTION_KINDS.TokenAssociate.name,
|
|
80
|
+
token: mockedTokenCurrency,
|
|
81
|
+
},
|
|
82
|
+
});
|
|
83
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockedAccount, mockedTransaction);
|
|
84
|
+
expect(result.amount).toEqual(new bignumber_js_1.default(0));
|
|
85
|
+
expect(result.errors).toEqual({});
|
|
86
|
+
expect(result.warnings).toEqual({});
|
|
87
|
+
expect(result.totalSpent).toEqual(mockedEstimatedFee);
|
|
88
|
+
expect(result.estimatedFees).toEqual(mockedEstimatedFee);
|
|
89
|
+
});
|
|
90
|
+
test("adds error for invalid recipient address", async () => {
|
|
91
|
+
const mockedAccount = (0, account_fixture_1.getMockedAccount)();
|
|
92
|
+
const mockedTransaction = (0, transaction_fixture_1.getMockedTransaction)({ recipient: invalidRecipientAddress });
|
|
93
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockedAccount, mockedTransaction);
|
|
94
|
+
expect(result.errors.recipient).toBeInstanceOf(errors_1.InvalidAddress);
|
|
95
|
+
});
|
|
96
|
+
test("adds error for self transfers", async () => {
|
|
97
|
+
const mockedAccount = (0, account_fixture_1.getMockedAccount)();
|
|
98
|
+
const mockedTransaction = (0, transaction_fixture_1.getMockedTransaction)({
|
|
99
|
+
recipient: mockedAccount.freshAddress,
|
|
100
|
+
});
|
|
101
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockedAccount, mockedTransaction);
|
|
102
|
+
expect(result.errors.recipient).toBeInstanceOf(errors_1.InvalidAddressBecauseDestinationIsAlsoSource);
|
|
103
|
+
});
|
|
104
|
+
test("adds error during coin transfer with insufficient balance", async () => {
|
|
105
|
+
const mockedAccount = (0, account_fixture_1.getMockedAccount)({ balance: new bignumber_js_1.default(0) });
|
|
106
|
+
const mockedTransaction = (0, transaction_fixture_1.getMockedTransaction)({
|
|
107
|
+
amount: new bignumber_js_1.default(100),
|
|
108
|
+
recipient: validRecipientAddress,
|
|
109
|
+
});
|
|
110
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockedAccount, mockedTransaction);
|
|
111
|
+
expect(result.errors.amount).toBeInstanceOf(errors_1.NotEnoughBalance);
|
|
112
|
+
});
|
|
113
|
+
test("adds error if USD balance is too low for token association", async () => {
|
|
114
|
+
const mockedTokenCurrency = (0, currency_fixture_1.getMockedTokenCurrency)();
|
|
115
|
+
const mockedAccount = (0, account_fixture_1.getMockedAccount)({ balance: new bignumber_js_1.default(0) });
|
|
116
|
+
const mockedTransaction = (0, transaction_fixture_1.getMockedTransaction)({
|
|
117
|
+
properties: {
|
|
118
|
+
name: constants_1.HEDERA_TRANSACTION_KINDS.TokenAssociate.name,
|
|
119
|
+
token: mockedTokenCurrency,
|
|
120
|
+
},
|
|
121
|
+
});
|
|
122
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockedAccount, mockedTransaction);
|
|
123
|
+
expect(result.errors.insufficientAssociateBalance).toBeInstanceOf(errors_1.HederaInsufficientFundsForAssociation);
|
|
124
|
+
});
|
|
125
|
+
test("adds warning during token transfer if recipient has no token associated", async () => {
|
|
126
|
+
jest.spyOn(utils, "checkAccountTokenAssociationStatus").mockResolvedValueOnce(false);
|
|
127
|
+
const mockedTokenCurrency = (0, currency_fixture_1.getMockedTokenCurrency)();
|
|
128
|
+
const mockedTokenAccount = (0, account_fixture_1.getMockedTokenAccount)(mockedTokenCurrency);
|
|
129
|
+
const mockedAccount = (0, account_fixture_1.getMockedAccount)({ subAccounts: [mockedTokenAccount] });
|
|
130
|
+
const mockedTransaction = (0, transaction_fixture_1.getMockedTransaction)({
|
|
131
|
+
subAccountId: mockedTokenAccount.id,
|
|
132
|
+
recipient: validRecipientAddress,
|
|
133
|
+
});
|
|
134
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockedAccount, mockedTransaction);
|
|
135
|
+
expect(result.warnings.missingAssociation).toBeInstanceOf(errors_1.HederaRecipientTokenAssociationRequired);
|
|
136
|
+
});
|
|
137
|
+
test("adds warning if token association status can't be verified", async () => {
|
|
138
|
+
jest
|
|
139
|
+
.spyOn(utils, "checkAccountTokenAssociationStatus")
|
|
140
|
+
.mockRejectedValueOnce(new errors_1.HederaRecipientTokenAssociationUnverified());
|
|
141
|
+
const mockedTokenCurrency = (0, currency_fixture_1.getMockedTokenCurrency)();
|
|
142
|
+
const mockedTokenAccount = (0, account_fixture_1.getMockedTokenAccount)(mockedTokenCurrency);
|
|
143
|
+
const mockedAccount = (0, account_fixture_1.getMockedAccount)({ subAccounts: [mockedTokenAccount] });
|
|
144
|
+
const mockedTransaction = (0, transaction_fixture_1.getMockedTransaction)({
|
|
145
|
+
subAccountId: mockedTokenAccount.id,
|
|
146
|
+
recipient: validRecipientAddress,
|
|
147
|
+
});
|
|
148
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockedAccount, mockedTransaction);
|
|
149
|
+
expect(result.warnings.unverifiedAssociation).toBeInstanceOf(errors_1.HederaRecipientTokenAssociationUnverified);
|
|
150
|
+
});
|
|
151
|
+
test("adds error during token transfer with insufficient balance", async () => {
|
|
152
|
+
const mockedTokenCurrency = (0, currency_fixture_1.getMockedTokenCurrency)();
|
|
153
|
+
const mockedTokenAccount = (0, account_fixture_1.getMockedTokenAccount)(mockedTokenCurrency, {
|
|
154
|
+
balance: new bignumber_js_1.default(0),
|
|
155
|
+
});
|
|
156
|
+
const mockedAccount = (0, account_fixture_1.getMockedAccount)({ subAccounts: [mockedTokenAccount] });
|
|
157
|
+
const mockedTransaction = (0, transaction_fixture_1.getMockedTransaction)({
|
|
158
|
+
subAccountId: mockedTokenAccount.id,
|
|
159
|
+
recipient: validRecipientAddress,
|
|
160
|
+
amount: new bignumber_js_1.default(100),
|
|
161
|
+
});
|
|
162
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockedAccount, mockedTransaction);
|
|
163
|
+
expect(result.errors.amount).toBeInstanceOf(errors_1.NotEnoughBalance);
|
|
164
|
+
});
|
|
165
|
+
test("adds error if amount is zero and useAllAmount is false", async () => {
|
|
166
|
+
const mockedAccount = (0, account_fixture_1.getMockedAccount)();
|
|
167
|
+
const mockedTransaction = (0, transaction_fixture_1.getMockedTransaction)({
|
|
168
|
+
recipient: validRecipientAddress,
|
|
169
|
+
amount: new bignumber_js_1.default(0),
|
|
170
|
+
useAllAmount: false,
|
|
171
|
+
});
|
|
172
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockedAccount, mockedTransaction);
|
|
173
|
+
expect(result.errors.amount).toBeInstanceOf(errors_1.AmountRequired);
|
|
174
|
+
});
|
|
175
|
+
});
|
|
176
|
+
//# sourceMappingURL=getTransactionStatus.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getTransactionStatus.test.js","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.test.ts"],"names":[],"mappings":"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"}
|
package/lib/bridge/index.d.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { SignerContext } from "@ledgerhq/coin-framework/signer";
|
|
2
|
-
import type {
|
|
3
|
-
import type { Transaction, HederaSigner } from "../types";
|
|
1
|
+
import type { SignerContext } from "@ledgerhq/coin-framework/signer";
|
|
2
|
+
import type { AccountBridge, CurrencyBridge } from "@ledgerhq/types-live";
|
|
3
|
+
import type { Transaction, HederaSigner, HederaAccount } from "../types";
|
|
4
4
|
export declare function createBridges(signerContext: SignerContext<HederaSigner>): {
|
|
5
5
|
currencyBridge: CurrencyBridge;
|
|
6
|
-
accountBridge: AccountBridge<Transaction,
|
|
6
|
+
accountBridge: AccountBridge<Transaction, HederaAccount, import("@ledgerhq/types-live").TransactionStatusCommon>;
|
|
7
7
|
};
|
|
8
8
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AACrE,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAW1E,OAAO,KAAK,EAAE,WAAW,EAAqB,YAAY,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AA2C5F,wBAAgB,aAAa,CAAC,aAAa,EAAE,aAAa,CAAC,YAAY,CAAC;;;EAKvE"}
|
package/lib/bridge/index.js
CHANGED
|
@@ -5,16 +5,17 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.createBridges = void 0;
|
|
7
7
|
const jsHelpers_1 = require("@ledgerhq/coin-framework/bridge/jsHelpers");
|
|
8
|
-
const index_1 = __importDefault(require("../signer/index"));
|
|
9
8
|
const getAddressWrapper_1 = __importDefault(require("@ledgerhq/coin-framework/bridge/getAddressWrapper"));
|
|
10
|
-
const
|
|
9
|
+
const broadcast_1 = require("./broadcast");
|
|
10
|
+
const createTransaction_1 = require("./createTransaction");
|
|
11
11
|
const estimateMaxSpendable_1 = require("./estimateMaxSpendable");
|
|
12
|
+
const getTransactionStatus_1 = require("./getTransactionStatus");
|
|
12
13
|
const prepareTransaction_1 = require("./prepareTransaction");
|
|
13
|
-
const createTransaction_1 = require("./createTransaction");
|
|
14
|
-
const synchronisation_1 = require("./synchronisation");
|
|
15
|
-
const signOperation_1 = require("./signOperation");
|
|
16
|
-
const broadcast_1 = require("./broadcast");
|
|
17
14
|
const receive_1 = require("./receive");
|
|
15
|
+
const signOperation_1 = require("./signOperation");
|
|
16
|
+
const synchronisation_1 = require("./synchronisation");
|
|
17
|
+
const serialization_1 = require("./serialization");
|
|
18
|
+
const index_1 = __importDefault(require("../signer/index"));
|
|
18
19
|
function buildCurrencyBridge(signerContext) {
|
|
19
20
|
const getAddress = (0, index_1.default)(signerContext);
|
|
20
21
|
const scanAccounts = (0, jsHelpers_1.makeScanAccounts)({
|
|
@@ -38,6 +39,8 @@ function buildAccountBridge(signerContext) {
|
|
|
38
39
|
updateTransaction: jsHelpers_1.updateTransaction,
|
|
39
40
|
getTransactionStatus: getTransactionStatus_1.getTransactionStatus,
|
|
40
41
|
prepareTransaction: prepareTransaction_1.prepareTransaction,
|
|
42
|
+
assignToAccountRaw: serialization_1.assignToAccountRaw,
|
|
43
|
+
assignFromAccountRaw: serialization_1.assignFromAccountRaw,
|
|
41
44
|
sync,
|
|
42
45
|
receive: (0, receive_1.receive)((0, getAddressWrapper_1.default)(getAddress)),
|
|
43
46
|
signOperation,
|
package/lib/bridge/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":";;;;;;AAAA,yEAKmD;AACnD,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":";;;;;;AAAA,yEAKmD;AACnD,0GAAkF;AAGlF,2CAAwC;AACxC,2DAAwD;AACxD,iEAA8D;AAC9D,iEAA8D;AAC9D,6DAA0D;AAC1D,uCAAoC;AACpC,mDAAqD;AACrD,uDAAwE;AACxE,mDAA2E;AAC3E,4DAAuC;AAGvC,SAAS,mBAAmB,CAAC,aAA0C;IACrE,MAAM,UAAU,GAAG,IAAA,eAAQ,EAAC,aAAa,CAAC,CAAC;IAE3C,MAAM,YAAY,GAAG,IAAA,4BAAgB,EAAC;QACpC,eAAe,EAAf,iCAAe;QACf,kBAAkB,EAAlB,oCAAkB;QAClB,YAAY,EAAE,IAAA,2BAAiB,EAAC,UAAU,CAAC;KAC5C,CAAC,CAAC;IAEH,OAAO;QACL,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;QAClC,OAAO,EAAE,GAAG,EAAE,GAAE,CAAC;QACjB,YAAY;KACb,CAAC;AACJ,CAAC;AAED,MAAM,IAAI,GAAG,IAAA,oBAAQ,EAAC,EAAE,eAAe,EAAf,iCAAe,EAAE,CAAC,CAAC;AAE3C,SAAS,kBAAkB,CACzB,aAA0C;IAE1C,MAAM,UAAU,GAAG,IAAA,eAAQ,EAAC,aAAa,CAAC,CAAC;IAE3C,MAAM,aAAa,GAAG,IAAA,kCAAkB,EAAC,aAAa,CAAC,CAAC;IAExD,OAAO;QACL,oBAAoB,EAApB,2CAAoB;QACpB,iBAAiB,EAAjB,qCAAiB;QACjB,iBAAiB,EAAjB,6BAAiB;QACjB,oBAAoB,EAApB,2CAAoB;QACpB,kBAAkB,EAAlB,uCAAkB;QAClB,kBAAkB,EAAlB,kCAAkB;QAClB,oBAAoB,EAApB,oCAAoB;QACpB,IAAI;QACJ,OAAO,EAAE,IAAA,iBAAO,EAAC,IAAA,2BAAiB,EAAC,UAAU,CAAC,CAAC;QAC/C,aAAa;QACb,SAAS,EAAT,qBAAS;QACT,8BAA8B,EAA9B,0CAA8B;KAC/B,CAAC;AACJ,CAAC;AAED,SAAgB,aAAa,CAAC,aAA0C;IACtE,OAAO;QACL,cAAc,EAAE,mBAAmB,CAAC,aAAa,CAAC;QAClD,aAAa,EAAE,kBAAkB,CAAC,aAAa,CAAC;KACjD,CAAC;AACJ,CAAC;AALD,sCAKC"}
|
|
@@ -6,58 +6,42 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
6
6
|
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
7
7
|
const _1 = require(".");
|
|
8
8
|
const utils_1 = require("./utils");
|
|
9
|
-
|
|
10
|
-
const
|
|
11
|
-
|
|
12
|
-
id: "",
|
|
13
|
-
seedIdentifier: "",
|
|
14
|
-
derivationMode: "",
|
|
15
|
-
index: 0,
|
|
16
|
-
freshAddress: "",
|
|
17
|
-
freshAddressPath: "",
|
|
18
|
-
used: false,
|
|
19
|
-
balance: new bignumber_js_1.default(100000000),
|
|
20
|
-
spendableBalance: new bignumber_js_1.default(0),
|
|
21
|
-
creationDate: new Date(),
|
|
22
|
-
blockHeight: 0,
|
|
23
|
-
currency: {
|
|
24
|
-
type: "CryptoCurrency",
|
|
25
|
-
id: "hedera",
|
|
26
|
-
managerAppName: "",
|
|
27
|
-
coinType: 0,
|
|
28
|
-
scheme: "",
|
|
29
|
-
color: "",
|
|
30
|
-
family: "",
|
|
31
|
-
explorerViews: [],
|
|
32
|
-
name: "",
|
|
33
|
-
ticker: "",
|
|
34
|
-
units: [],
|
|
35
|
-
},
|
|
36
|
-
operationsCount: 0,
|
|
37
|
-
operations: [],
|
|
38
|
-
pendingOperations: [],
|
|
39
|
-
lastSyncDate: new Date(),
|
|
40
|
-
balanceHistoryCache: {
|
|
41
|
-
HOUR: { latestDate: null, balances: [] },
|
|
42
|
-
DAY: { latestDate: null, balances: [] },
|
|
43
|
-
WEEK: { latestDate: null, balances: [] },
|
|
44
|
-
},
|
|
45
|
-
swapHistory: [],
|
|
46
|
-
};
|
|
9
|
+
const account_fixture_1 = require("../test/fixtures/account.fixture");
|
|
10
|
+
const currency_fixture_1 = require("../test/fixtures/currency.fixture");
|
|
11
|
+
const constants_1 = require("../constants");
|
|
47
12
|
describe("js-estimateMaxSpendable", () => {
|
|
48
13
|
let bridge;
|
|
49
|
-
let estimatedFees
|
|
14
|
+
let estimatedFees;
|
|
50
15
|
beforeAll(async () => {
|
|
51
16
|
const signer = jest.fn();
|
|
52
17
|
bridge = (0, _1.createBridges)(signer);
|
|
53
|
-
|
|
18
|
+
const mockedAccount = (0, account_fixture_1.getMockedAccount)();
|
|
19
|
+
const crypto = await (0, utils_1.getEstimatedFees)(mockedAccount, constants_1.HEDERA_OPERATION_TYPES.CryptoTransfer);
|
|
20
|
+
estimatedFees = { crypto };
|
|
21
|
+
});
|
|
22
|
+
test("estimateMaxSpendable returns balance minus fee", async () => {
|
|
23
|
+
const mockedAccount = (0, account_fixture_1.getMockedAccount)();
|
|
24
|
+
const result = await bridge.accountBridge.estimateMaxSpendable({
|
|
25
|
+
account: mockedAccount,
|
|
26
|
+
});
|
|
27
|
+
expect(result).toEqual(mockedAccount.balance.minus(estimatedFees.crypto));
|
|
28
|
+
});
|
|
29
|
+
test("estimateMaxSpendable returns 0 if balance < estimated fees", async () => {
|
|
30
|
+
const mockedAccount = (0, account_fixture_1.getMockedAccount)({ balance: estimatedFees.crypto.minus(1) });
|
|
31
|
+
const result = await bridge.accountBridge.estimateMaxSpendable({
|
|
32
|
+
account: mockedAccount,
|
|
33
|
+
});
|
|
34
|
+
expect(result).toEqual(new bignumber_js_1.default(0));
|
|
54
35
|
});
|
|
55
|
-
test("estimateMaxSpendable", async () => {
|
|
36
|
+
test("estimateMaxSpendable returns token balance for token account", async () => {
|
|
37
|
+
const mockedTokenCurrency = (0, currency_fixture_1.getMockedTokenCurrency)();
|
|
38
|
+
const mockedTokenAccount = (0, account_fixture_1.getMockedTokenAccount)(mockedTokenCurrency);
|
|
39
|
+
const mockedAccount = (0, account_fixture_1.getMockedAccount)({ subAccounts: [mockedTokenAccount] });
|
|
56
40
|
const result = await bridge.accountBridge.estimateMaxSpendable({
|
|
57
|
-
account,
|
|
41
|
+
account: mockedTokenAccount,
|
|
42
|
+
parentAccount: mockedAccount,
|
|
58
43
|
});
|
|
59
|
-
|
|
60
|
-
expect(result).toEqual(data);
|
|
44
|
+
expect(result).toEqual(mockedTokenAccount.balance);
|
|
61
45
|
});
|
|
62
46
|
});
|
|
63
47
|
//# sourceMappingURL=js-estimateMaxSpendable.integration.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"js-estimateMaxSpendable.integration.test.js","sourceRoot":"","sources":["../../src/bridge/js-estimateMaxSpendable.integration.test.ts"],"names":[],"mappings":";;;;;AAAA,gEAAqC;
|
|
1
|
+
{"version":3,"file":"js-estimateMaxSpendable.integration.test.js","sourceRoot":"","sources":["../../src/bridge/js-estimateMaxSpendable.integration.test.ts"],"names":[],"mappings":";;;;;AAAA,gEAAqC;AACrC,wBAAkC;AAClC,mCAA2C;AAC3C,sEAA2F;AAC3F,wEAA2E;AAC3E,4CAAsD;AAEtD,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;IACvC,IAAI,MAAwC,CAAC;IAC7C,IAAI,aAA0C,CAAC;IAE/C,SAAS,CAAC,KAAK,IAAI,EAAE;QACnB,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;QACzB,MAAM,GAAG,IAAA,gBAAa,EAAC,MAAM,CAAC,CAAC;QAE/B,MAAM,aAAa,GAAG,IAAA,kCAAgB,GAAE,CAAC;QACzC,MAAM,MAAM,GAAG,MAAM,IAAA,wBAAgB,EAAC,aAAa,EAAE,kCAAsB,CAAC,cAAc,CAAC,CAAC;QAE5F,aAAa,GAAG,EAAE,MAAM,EAAE,CAAC;IAC7B,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,gDAAgD,EAAE,KAAK,IAAI,EAAE;QAChE,MAAM,aAAa,GAAG,IAAA,kCAAgB,GAAE,CAAC;QAEzC,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,oBAAoB,CAAC;YAC7D,OAAO,EAAE,aAAa;SACvB,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC;IAC5E,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,4DAA4D,EAAE,KAAK,IAAI,EAAE;QAC5E,MAAM,aAAa,GAAG,IAAA,kCAAgB,EAAC,EAAE,OAAO,EAAE,aAAa,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAEnF,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,oBAAoB,CAAC;YAC7D,OAAO,EAAE,aAAa;SACvB,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,IAAI,sBAAS,CAAC,CAAC,CAAC,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,8DAA8D,EAAE,KAAK,IAAI,EAAE;QAC9E,MAAM,mBAAmB,GAAG,IAAA,yCAAsB,GAAE,CAAC;QACrD,MAAM,kBAAkB,GAAG,IAAA,uCAAqB,EAAC,mBAAmB,CAAC,CAAC;QACtE,MAAM,aAAa,GAAG,IAAA,kCAAgB,EAAC,EAAE,WAAW,EAAE,CAAC,kBAAkB,CAAC,EAAE,CAAC,CAAC;QAE9E,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,oBAAoB,CAAC;YAC7D,OAAO,EAAE,kBAAkB;YAC3B,aAAa,EAAE,aAAa;SAC7B,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -6,58 +6,19 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
6
6
|
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
7
7
|
const jsHelpers_1 = require("@ledgerhq/coin-framework/bridge/jsHelpers");
|
|
8
8
|
const _1 = require(".");
|
|
9
|
-
const
|
|
10
|
-
|
|
11
|
-
id: "",
|
|
12
|
-
seedIdentifier: "",
|
|
13
|
-
derivationMode: "",
|
|
14
|
-
index: 0,
|
|
15
|
-
freshAddress: "",
|
|
16
|
-
freshAddressPath: "",
|
|
17
|
-
used: false,
|
|
18
|
-
balance: new bignumber_js_1.default(200000),
|
|
19
|
-
spendableBalance: new bignumber_js_1.default(0),
|
|
20
|
-
creationDate: new Date(),
|
|
21
|
-
blockHeight: 0,
|
|
22
|
-
currency: {
|
|
23
|
-
type: "CryptoCurrency",
|
|
24
|
-
id: "hedera",
|
|
25
|
-
managerAppName: "",
|
|
26
|
-
coinType: 0,
|
|
27
|
-
scheme: "",
|
|
28
|
-
color: "",
|
|
29
|
-
family: "",
|
|
30
|
-
explorerViews: [],
|
|
31
|
-
name: "",
|
|
32
|
-
ticker: "",
|
|
33
|
-
units: [],
|
|
34
|
-
},
|
|
35
|
-
operationsCount: 0,
|
|
36
|
-
operations: [],
|
|
37
|
-
pendingOperations: [],
|
|
38
|
-
lastSyncDate: new Date(),
|
|
39
|
-
balanceHistoryCache: {
|
|
40
|
-
HOUR: { latestDate: null, balances: [] },
|
|
41
|
-
DAY: { latestDate: null, balances: [] },
|
|
42
|
-
WEEK: { latestDate: null, balances: [] },
|
|
43
|
-
},
|
|
44
|
-
swapHistory: [],
|
|
45
|
-
};
|
|
46
|
-
const transaction = {
|
|
47
|
-
family: "hedera",
|
|
48
|
-
amount: new bignumber_js_1.default(0),
|
|
49
|
-
recipient: "",
|
|
50
|
-
useAllAmount: false,
|
|
51
|
-
};
|
|
9
|
+
const account_fixture_1 = require("../test/fixtures/account.fixture");
|
|
10
|
+
const transaction_fixture_1 = require("../test/fixtures/transaction.fixture");
|
|
52
11
|
describe("js-transaction", () => {
|
|
53
12
|
let bridge;
|
|
13
|
+
const mockedAccount = (0, account_fixture_1.getMockedAccount)();
|
|
14
|
+
const mockedTransaction = (0, transaction_fixture_1.getMockedTransaction)();
|
|
54
15
|
beforeAll(() => {
|
|
55
16
|
const signer = jest.fn();
|
|
56
17
|
bridge = (0, _1.createBridges)(signer);
|
|
57
18
|
});
|
|
58
19
|
test("createTransaction", () => {
|
|
59
|
-
const data =
|
|
60
|
-
const result = bridge.accountBridge.createTransaction(
|
|
20
|
+
const data = mockedTransaction;
|
|
21
|
+
const result = bridge.accountBridge.createTransaction(mockedAccount);
|
|
61
22
|
expect(result).toEqual(data);
|
|
62
23
|
});
|
|
63
24
|
test("updateTransaction", () => {
|
|
@@ -66,13 +27,13 @@ describe("js-transaction", () => {
|
|
|
66
27
|
recipient: "0.0.3",
|
|
67
28
|
useAllAmount: true,
|
|
68
29
|
};
|
|
69
|
-
const data = { ...
|
|
70
|
-
const result = (0, jsHelpers_1.updateTransaction)(
|
|
30
|
+
const data = { ...mockedTransaction, ...patch };
|
|
31
|
+
const result = (0, jsHelpers_1.updateTransaction)(mockedTransaction, patch);
|
|
71
32
|
expect(result).toEqual(data);
|
|
72
33
|
});
|
|
73
34
|
test("prepareTransaction", async () => {
|
|
74
|
-
const data =
|
|
75
|
-
const result = await bridge.accountBridge.prepareTransaction(
|
|
35
|
+
const data = mockedTransaction;
|
|
36
|
+
const result = await bridge.accountBridge.prepareTransaction(mockedAccount, mockedTransaction);
|
|
76
37
|
expect(result).toEqual(data);
|
|
77
38
|
});
|
|
78
39
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"js-transaction.test.js","sourceRoot":"","sources":["../../src/bridge/js-transaction.test.ts"],"names":[],"mappings":";;;;;AAAA,gEAAqC;
|
|
1
|
+
{"version":3,"file":"js-transaction.test.js","sourceRoot":"","sources":["../../src/bridge/js-transaction.test.ts"],"names":[],"mappings":";;;;;AAAA,gEAAqC;AACrC,yEAA8E;AAC9E,wBAAkC;AAClC,sEAAoE;AACpE,8EAA4E;AAG5E,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;IAC9B,IAAI,MAAwC,CAAC;IAC7C,MAAM,aAAa,GAAG,IAAA,kCAAgB,GAAE,CAAC;IACzC,MAAM,iBAAiB,GAAG,IAAA,0CAAoB,GAAE,CAAC;IAEjD,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;QACzB,MAAM,GAAG,IAAA,gBAAa,EAAC,MAAM,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,mBAAmB,EAAE,GAAG,EAAE;QAC7B,MAAM,IAAI,GAAG,iBAAiB,CAAC;QAC/B,MAAM,MAAM,GAAG,MAAM,CAAC,aAAa,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAC;QAErE,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,mBAAmB,EAAE,GAAG,EAAE;QAC7B,MAAM,KAAK,GAAyB;YAClC,MAAM,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC;YACxB,SAAS,EAAE,OAAO;YAClB,YAAY,EAAE,IAAI;SACnB,CAAC;QACF,MAAM,IAAI,GAAG,EAAE,GAAG,iBAAiB,EAAE,GAAG,KAAK,EAAE,CAAC;QAChD,MAAM,MAAM,GAAG,IAAA,6BAAiB,EAAC,iBAAiB,EAAE,KAAK,CAAC,CAAC;QAE3D,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,oBAAoB,EAAE,KAAK,IAAI,EAAE;QACpC,MAAM,IAAI,GAAG,iBAAiB,CAAC;QAC/B,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,kBAAkB,CAAC,aAAa,EAAE,iBAAiB,CAAC,CAAC;QAE/F,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -7,7 +7,6 @@ import type { Transaction } from "../types";
|
|
|
7
7
|
* Hedera has fully client-side transactions and the fee
|
|
8
8
|
* is not possible to estimate ahead-of-time.
|
|
9
9
|
*
|
|
10
|
-
* @returns {Transaction}
|
|
11
10
|
*/
|
|
12
11
|
export declare const prepareTransaction: AccountBridge<Transaction>["prepareTransaction"];
|
|
13
12
|
//# sourceMappingURL=prepareTransaction.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prepareTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAG5C
|
|
1
|
+
{"version":3,"file":"prepareTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAG5C;;;;;;;GAOG;AACH,eAAO,MAAM,kBAAkB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,oBAAoB,CAU/E,CAAC"}
|
|
@@ -9,7 +9,6 @@ const utils_1 = require("./utils");
|
|
|
9
9
|
* Hedera has fully client-side transactions and the fee
|
|
10
10
|
* is not possible to estimate ahead-of-time.
|
|
11
11
|
*
|
|
12
|
-
* @returns {Transaction}
|
|
13
12
|
*/
|
|
14
13
|
const prepareTransaction = async (account, transaction) => {
|
|
15
14
|
// explicitly calculate transaction amount to account for `useAllAmount` flag (send max flow)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prepareTransaction.js","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":";;;AAEA,mCAA0C;AAE1C
|
|
1
|
+
{"version":3,"file":"prepareTransaction.js","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":";;;AAEA,mCAA0C;AAE1C;;;;;;;GAOG;AACI,MAAM,kBAAkB,GAAqD,KAAK,EACvF,OAAO,EACP,WAAW,EACW,EAAE;IACxB,6FAA6F;IAC7F,uHAAuH;IACvH,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,IAAA,uBAAe,EAAC,EAAE,OAAO,EAAE,WAAW,EAAE,CAAC,CAAC;IACnE,WAAW,CAAC,MAAM,GAAG,MAAM,CAAC;IAE5B,OAAO,WAAW,CAAC;AACrB,CAAC,CAAC;AAVW,QAAA,kBAAkB,sBAU7B"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { AccountRaw, Account } from "@ledgerhq/types-live";
|
|
2
|
+
import type { HederaResources, HederaResourcesRaw } from "../types";
|
|
3
|
+
export declare function toHederaResourcesRaw(resources: HederaResources): HederaResourcesRaw;
|
|
4
|
+
export declare function fromHederaResourcesRaw(rawResources: HederaResourcesRaw): HederaResources;
|
|
5
|
+
export declare function assignToAccountRaw(account: Account, accountRaw: AccountRaw): void;
|
|
6
|
+
export declare function assignFromAccountRaw(accountRaw: AccountRaw, account: Account): void;
|
|
7
|
+
//# sourceMappingURL=serialization.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"serialization.d.ts","sourceRoot":"","sources":["../../src/bridge/serialization.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAChE,OAAO,KAAK,EAGV,eAAe,EACf,kBAAkB,EACnB,MAAM,UAAU,CAAC;AAElB,wBAAgB,oBAAoB,CAAC,SAAS,EAAE,eAAe,GAAG,kBAAkB,CAOnF;AAED,wBAAgB,sBAAsB,CAAC,YAAY,EAAE,kBAAkB,GAAG,eAAe,CAOxF;AAED,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,GAAG,IAAI,CAOjF;AAED,wBAAgB,oBAAoB,CAAC,UAAU,EAAE,UAAU,EAAE,OAAO,EAAE,OAAO,QAO5E"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.assignFromAccountRaw = exports.assignToAccountRaw = exports.fromHederaResourcesRaw = exports.toHederaResourcesRaw = void 0;
|
|
4
|
+
function toHederaResourcesRaw(resources) {
|
|
5
|
+
const { maxAutomaticTokenAssociations, isAutoTokenAssociationEnabled } = resources;
|
|
6
|
+
return {
|
|
7
|
+
maxAutomaticTokenAssociations,
|
|
8
|
+
isAutoTokenAssociationEnabled,
|
|
9
|
+
};
|
|
10
|
+
}
|
|
11
|
+
exports.toHederaResourcesRaw = toHederaResourcesRaw;
|
|
12
|
+
function fromHederaResourcesRaw(rawResources) {
|
|
13
|
+
const { maxAutomaticTokenAssociations, isAutoTokenAssociationEnabled } = rawResources;
|
|
14
|
+
return {
|
|
15
|
+
maxAutomaticTokenAssociations,
|
|
16
|
+
isAutoTokenAssociationEnabled,
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
exports.fromHederaResourcesRaw = fromHederaResourcesRaw;
|
|
20
|
+
function assignToAccountRaw(account, accountRaw) {
|
|
21
|
+
const hederaAccount = account;
|
|
22
|
+
const hederaAccountRaw = accountRaw;
|
|
23
|
+
if (hederaAccount.hederaResources) {
|
|
24
|
+
hederaAccountRaw.hederaResources = toHederaResourcesRaw(hederaAccount.hederaResources);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
exports.assignToAccountRaw = assignToAccountRaw;
|
|
28
|
+
function assignFromAccountRaw(accountRaw, account) {
|
|
29
|
+
const hederaAccount = account;
|
|
30
|
+
const hederaAccountRaw = accountRaw;
|
|
31
|
+
if (hederaAccountRaw.hederaResources) {
|
|
32
|
+
hederaAccount.hederaResources = fromHederaResourcesRaw(hederaAccountRaw.hederaResources);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
exports.assignFromAccountRaw = assignFromAccountRaw;
|
|
36
|
+
//# sourceMappingURL=serialization.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"serialization.js","sourceRoot":"","sources":["../../src/bridge/serialization.ts"],"names":[],"mappings":";;;AAQA,SAAgB,oBAAoB,CAAC,SAA0B;IAC7D,MAAM,EAAE,6BAA6B,EAAE,6BAA6B,EAAE,GAAG,SAAS,CAAC;IAEnF,OAAO;QACL,6BAA6B;QAC7B,6BAA6B;KAC9B,CAAC;AACJ,CAAC;AAPD,oDAOC;AAED,SAAgB,sBAAsB,CAAC,YAAgC;IACrE,MAAM,EAAE,6BAA6B,EAAE,6BAA6B,EAAE,GAAG,YAAY,CAAC;IAEtF,OAAO;QACL,6BAA6B;QAC7B,6BAA6B;KAC9B,CAAC;AACJ,CAAC;AAPD,wDAOC;AAED,SAAgB,kBAAkB,CAAC,OAAgB,EAAE,UAAsB;IACzE,MAAM,aAAa,GAAG,OAAwB,CAAC;IAC/C,MAAM,gBAAgB,GAAG,UAA8B,CAAC;IAExD,IAAI,aAAa,CAAC,eAAe,EAAE,CAAC;QAClC,gBAAgB,CAAC,eAAe,GAAG,oBAAoB,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC;IACzF,CAAC;AACH,CAAC;AAPD,gDAOC;AAED,SAAgB,oBAAoB,CAAC,UAAsB,EAAE,OAAgB;IAC3E,MAAM,aAAa,GAAG,OAAwB,CAAC;IAC/C,MAAM,gBAAgB,GAAG,UAA8B,CAAC;IAExD,IAAI,gBAAgB,CAAC,eAAe,EAAE,CAAC;QACrC,aAAa,CAAC,eAAe,GAAG,sBAAsB,CAAC,gBAAgB,CAAC,eAAe,CAAC,CAAC;IAC3F,CAAC;AACH,CAAC;AAPD,oDAOC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"serialization.test.d.ts","sourceRoot":"","sources":["../../src/bridge/serialization.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const account_fixture_1 = require("../test/fixtures/account.fixture");
|
|
4
|
+
const serialization_1 = require("./serialization");
|
|
5
|
+
const mockedAccount = (0, account_fixture_1.getMockedAccount)();
|
|
6
|
+
const mockedAccountRaw = (0, account_fixture_1.getMockedAccountRaw)();
|
|
7
|
+
describe("serialization", () => {
|
|
8
|
+
test("toHederaResourcesRaw should convert HederaResources to HederaResourcesRaw", () => {
|
|
9
|
+
const result = (0, serialization_1.toHederaResourcesRaw)(account_fixture_1.mockHederaResources);
|
|
10
|
+
expect(result).toEqual(account_fixture_1.mockHederaResourcesRaw);
|
|
11
|
+
});
|
|
12
|
+
test("fromHederaResourcesRaw should convert HederaResourcesRaw to HederaResources", () => {
|
|
13
|
+
const result = (0, serialization_1.fromHederaResourcesRaw)(account_fixture_1.mockHederaResourcesRaw);
|
|
14
|
+
expect(result).toEqual(account_fixture_1.mockHederaResources);
|
|
15
|
+
});
|
|
16
|
+
test("assignToAccountRaw should assign HederaResources to AccountRaw", () => {
|
|
17
|
+
(0, serialization_1.assignToAccountRaw)(mockedAccount, mockedAccountRaw);
|
|
18
|
+
expect(typeof mockedAccountRaw.hederaResources).toBe("object");
|
|
19
|
+
expect(mockedAccountRaw.hederaResources).not.toBeNull();
|
|
20
|
+
});
|
|
21
|
+
test("assignFromAccountRaw should assign HederaResourcesRaw to Account", () => {
|
|
22
|
+
(0, serialization_1.assignFromAccountRaw)(mockedAccountRaw, mockedAccount);
|
|
23
|
+
expect(typeof mockedAccountRaw.hederaResources).toBe("object");
|
|
24
|
+
expect(mockedAccountRaw.hederaResources).not.toBeNull();
|
|
25
|
+
});
|
|
26
|
+
});
|
|
27
|
+
//# sourceMappingURL=serialization.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"serialization.test.js","sourceRoot":"","sources":["../../src/bridge/serialization.test.ts"],"names":[],"mappings":";;AAAA,sEAK0C;AAC1C,mDAKyB;AAEzB,MAAM,aAAa,GAAG,IAAA,kCAAgB,GAAE,CAAC;AACzC,MAAM,gBAAgB,GAAG,IAAA,qCAAmB,GAAE,CAAC;AAE/C,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;IAC7B,IAAI,CAAC,2EAA2E,EAAE,GAAG,EAAE;QACrF,MAAM,MAAM,GAAG,IAAA,oCAAoB,EAAC,qCAAmB,CAAC,CAAC;QACzD,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,wCAAsB,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,6EAA6E,EAAE,GAAG,EAAE;QACvF,MAAM,MAAM,GAAG,IAAA,sCAAsB,EAAC,wCAAsB,CAAC,CAAC;QAC9D,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,qCAAmB,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,gEAAgE,EAAE,GAAG,EAAE;QAC1E,IAAA,kCAAkB,EAAC,aAAa,EAAE,gBAAgB,CAAC,CAAC;QACpD,MAAM,CAAC,OAAO,gBAAgB,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC/D,MAAM,CAAC,gBAAgB,CAAC,eAAe,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IAC1D,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,kEAAkE,EAAE,GAAG,EAAE;QAC5E,IAAA,oCAAoB,EAAC,gBAAgB,EAAE,aAAa,CAAC,CAAC;QACtD,MAAM,CAAC,OAAO,gBAAgB,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC/D,MAAM,CAAC,gBAAgB,CAAC,eAAe,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IAC1D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import type {
|
|
2
|
-
import {
|
|
3
|
-
export declare const getAccountShape: GetAccountShape<
|
|
1
|
+
import type { GetAccountShape, IterateResultBuilder } from "@ledgerhq/coin-framework/bridge/jsHelpers";
|
|
2
|
+
import type { HederaAccount } from "../types";
|
|
3
|
+
export declare const getAccountShape: GetAccountShape<HederaAccount>;
|
|
4
4
|
export declare const buildIterateResult: IterateResultBuilder;
|
|
5
5
|
//# sourceMappingURL=synchronisation.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"synchronisation.d.ts","sourceRoot":"","sources":["../../src/bridge/synchronisation.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"synchronisation.d.ts","sourceRoot":"","sources":["../../src/bridge/synchronisation.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EACV,eAAe,EACf,oBAAoB,EACrB,MAAM,2CAA2C,CAAC;AAWnD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAG9C,eAAO,MAAM,eAAe,EAAE,eAAe,CAAC,aAAa,CA4E1D,CAAC;AAEF,eAAO,MAAM,kBAAkB,EAAE,oBAqBhC,CAAC"}
|