@ledgerhq/coin-cardano 0.16.0-nightly.20251211024123 → 0.16.0-nightly.20251213023821
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/CHANGELOG.md +12 -10
- package/lib/bridge/index.d.ts.map +1 -1
- package/lib/bridge/index.js +2 -0
- package/lib/bridge/index.js.map +1 -1
- package/lib/validateAddress.d.ts +3 -0
- package/lib/validateAddress.d.ts.map +1 -0
- package/lib/validateAddress.js +12 -0
- package/lib/validateAddress.js.map +1 -0
- package/lib-es/bridge/index.d.ts.map +1 -1
- package/lib-es/bridge/index.js +2 -0
- package/lib-es/bridge/index.js.map +1 -1
- package/lib-es/validateAddress.d.ts +3 -0
- package/lib-es/validateAddress.d.ts.map +1 -0
- package/lib-es/validateAddress.js +8 -0
- package/lib-es/validateAddress.js.map +1 -0
- package/package.json +9 -9
- package/src/bridge/index.ts +2 -0
- package/src/validateAddress.test.ts +33 -0
- package/src/validateAddress.ts +13 -0
- package/tsconfig.json +7 -2
package/CHANGELOG.md
CHANGED
|
@@ -1,24 +1,26 @@
|
|
|
1
1
|
# @ledgerhq/coin-cardano
|
|
2
2
|
|
|
3
|
-
## 0.16.0-nightly.
|
|
3
|
+
## 0.16.0-nightly.20251213023821
|
|
4
4
|
|
|
5
5
|
### Minor Changes
|
|
6
6
|
|
|
7
7
|
- [#13142](https://github.com/LedgerHQ/ledger-live/pull/13142) [`bdacedf`](https://github.com/LedgerHQ/ledger-live/commit/bdacedfe32bea8ffce96ab675a44c0d7cf395143) Thanks [@mcayuelas-ledger](https://github.com/mcayuelas-ledger)! - upgrade typescript-eslint rules & versions
|
|
8
8
|
|
|
9
|
+
- [#12967](https://github.com/LedgerHQ/ledger-live/pull/12967) [`5e8d6be`](https://github.com/LedgerHQ/ledger-live/commit/5e8d6be609dd37c48d747890e56189e0716d5273) Thanks [@Moustafa-Koterba](https://github.com/Moustafa-Koterba)! - Validate address implementation on all currencies
|
|
10
|
+
|
|
9
11
|
- [#13155](https://github.com/LedgerHQ/ledger-live/pull/13155) [`aadb3d5`](https://github.com/LedgerHQ/ledger-live/commit/aadb3d57f5719cc2cc397975eafec8094b160afe) Thanks [@gre-ledger](https://github.com/gre-ledger)! - rxjs@7.8.2 everywhere
|
|
10
12
|
|
|
11
13
|
### Patch Changes
|
|
12
14
|
|
|
13
|
-
- Updated dependencies [[`480a08a`](https://github.com/LedgerHQ/ledger-live/commit/480a08ae190119829910b46ecc6d2a9fb11bb7c2), [`19a54fd`](https://github.com/LedgerHQ/ledger-live/commit/19a54fd89a2d3c7481aebc28817870875f9d44dc), [`bc76d51`](https://github.com/LedgerHQ/ledger-live/commit/bc76d5154d35f8340b6b282c4909cd26920b8d40), [`7ae71b6`](https://github.com/LedgerHQ/ledger-live/commit/7ae71b64161424b398b63f77da5127085143fcdc), [`5fa83e4`](https://github.com/LedgerHQ/ledger-live/commit/5fa83e49c5fb103da7ecf0777b7e75bb35d5ed61), [`c5da2ce`](https://github.com/LedgerHQ/ledger-live/commit/c5da2cef7cded2b53c1af9aa3174cd27e5c92e0a), [`450f518`](https://github.com/LedgerHQ/ledger-live/commit/450f518d4cedb828c5fe1e7ccffaabd483f53226), [`30be235`](https://github.com/LedgerHQ/ledger-live/commit/30be2354822b3497c69322294ff1dab43375be50), [`bdacedf`](https://github.com/LedgerHQ/ledger-live/commit/bdacedfe32bea8ffce96ab675a44c0d7cf395143), [`768718d`](https://github.com/LedgerHQ/ledger-live/commit/768718df029bc8799b88c0299925dc56302b0c53), [`a5ad7d4`](https://github.com/LedgerHQ/ledger-live/commit/a5ad7d4578c06db3e40f260451b644c27e20cb62), [`3e70677`](https://github.com/LedgerHQ/ledger-live/commit/3e706774f8c4e9b768ab18b67abc3471cf61b6b6), [`aadb3d5`](https://github.com/LedgerHQ/ledger-live/commit/aadb3d57f5719cc2cc397975eafec8094b160afe), [`e44d216`](https://github.com/LedgerHQ/ledger-live/commit/e44d216d516df87e13f033ed64fedc1ce96380f4), [`d4bad44`](https://github.com/LedgerHQ/ledger-live/commit/d4bad4433c3fb083d95820d2927a9e8beeaf244f), [`8d8e1b7`](https://github.com/LedgerHQ/ledger-live/commit/8d8e1b7bb26305af326ea21710248223d1e8653b), [`07de7a8`](https://github.com/LedgerHQ/ledger-live/commit/07de7a87415ae4d1126e751d6a4d521ced3065e3), [`d37fa4b`](https://github.com/LedgerHQ/ledger-live/commit/d37fa4baf4534161bffe5033ce44fc7780c79d89), [`5e0556a`](https://github.com/LedgerHQ/ledger-live/commit/5e0556a3bd0ea60277462eed10c997b17b09d299), [`bce6610`](https://github.com/LedgerHQ/ledger-live/commit/bce6610ca8554a85f8f17b6014e921fdecd3fa4f), [`2a60165`](https://github.com/LedgerHQ/ledger-live/commit/2a601656b7a23a424a29f006ec53090648fdae4f), [`2d9f320`](https://github.com/LedgerHQ/ledger-live/commit/2d9f32087eea12ae9d5ea2347b277b8bf4e60f55), [`c56ab86`](https://github.com/LedgerHQ/ledger-live/commit/c56ab86ab65597caf87a09b7596faa54f3104bd4)]:
|
|
14
|
-
- @ledgerhq/coin-framework@6.11.0-nightly.
|
|
15
|
-
- @ledgerhq/types-live@6.91.0-nightly.
|
|
16
|
-
- @ledgerhq/cryptoassets@13.35.0-nightly.
|
|
17
|
-
- @ledgerhq/errors@6.28.0-nightly.
|
|
18
|
-
- @ledgerhq/live-env@2.23.0-nightly.
|
|
19
|
-
- @ledgerhq/devices@8.8.0-nightly.
|
|
20
|
-
- @ledgerhq/types-cryptoassets@7.31.0-nightly.
|
|
21
|
-
- @ledgerhq/live-network@2.1.3-nightly.
|
|
15
|
+
- Updated dependencies [[`480a08a`](https://github.com/LedgerHQ/ledger-live/commit/480a08ae190119829910b46ecc6d2a9fb11bb7c2), [`19a54fd`](https://github.com/LedgerHQ/ledger-live/commit/19a54fd89a2d3c7481aebc28817870875f9d44dc), [`e63194f`](https://github.com/LedgerHQ/ledger-live/commit/e63194f7dbd5ff2b0135c26aac3842a2be676b0a), [`bc76d51`](https://github.com/LedgerHQ/ledger-live/commit/bc76d5154d35f8340b6b282c4909cd26920b8d40), [`4be69a7`](https://github.com/LedgerHQ/ledger-live/commit/4be69a71dcd7624a1cba8dd1b1847ef009eb2d83), [`7ae71b6`](https://github.com/LedgerHQ/ledger-live/commit/7ae71b64161424b398b63f77da5127085143fcdc), [`5fa83e4`](https://github.com/LedgerHQ/ledger-live/commit/5fa83e49c5fb103da7ecf0777b7e75bb35d5ed61), [`c5da2ce`](https://github.com/LedgerHQ/ledger-live/commit/c5da2cef7cded2b53c1af9aa3174cd27e5c92e0a), [`450f518`](https://github.com/LedgerHQ/ledger-live/commit/450f518d4cedb828c5fe1e7ccffaabd483f53226), [`30be235`](https://github.com/LedgerHQ/ledger-live/commit/30be2354822b3497c69322294ff1dab43375be50), [`bdacedf`](https://github.com/LedgerHQ/ledger-live/commit/bdacedfe32bea8ffce96ab675a44c0d7cf395143), [`5e8d6be`](https://github.com/LedgerHQ/ledger-live/commit/5e8d6be609dd37c48d747890e56189e0716d5273), [`768718d`](https://github.com/LedgerHQ/ledger-live/commit/768718df029bc8799b88c0299925dc56302b0c53), [`a5ad7d4`](https://github.com/LedgerHQ/ledger-live/commit/a5ad7d4578c06db3e40f260451b644c27e20cb62), [`3e70677`](https://github.com/LedgerHQ/ledger-live/commit/3e706774f8c4e9b768ab18b67abc3471cf61b6b6), [`aadb3d5`](https://github.com/LedgerHQ/ledger-live/commit/aadb3d57f5719cc2cc397975eafec8094b160afe), [`e44d216`](https://github.com/LedgerHQ/ledger-live/commit/e44d216d516df87e13f033ed64fedc1ce96380f4), [`d4bad44`](https://github.com/LedgerHQ/ledger-live/commit/d4bad4433c3fb083d95820d2927a9e8beeaf244f), [`8d8e1b7`](https://github.com/LedgerHQ/ledger-live/commit/8d8e1b7bb26305af326ea21710248223d1e8653b), [`07de7a8`](https://github.com/LedgerHQ/ledger-live/commit/07de7a87415ae4d1126e751d6a4d521ced3065e3), [`d37fa4b`](https://github.com/LedgerHQ/ledger-live/commit/d37fa4baf4534161bffe5033ce44fc7780c79d89), [`5e0556a`](https://github.com/LedgerHQ/ledger-live/commit/5e0556a3bd0ea60277462eed10c997b17b09d299), [`bce6610`](https://github.com/LedgerHQ/ledger-live/commit/bce6610ca8554a85f8f17b6014e921fdecd3fa4f), [`2a60165`](https://github.com/LedgerHQ/ledger-live/commit/2a601656b7a23a424a29f006ec53090648fdae4f), [`2d9f320`](https://github.com/LedgerHQ/ledger-live/commit/2d9f32087eea12ae9d5ea2347b277b8bf4e60f55), [`c56ab86`](https://github.com/LedgerHQ/ledger-live/commit/c56ab86ab65597caf87a09b7596faa54f3104bd4)]:
|
|
16
|
+
- @ledgerhq/coin-framework@6.11.0-nightly.20251213023821
|
|
17
|
+
- @ledgerhq/types-live@6.91.0-nightly.20251213023821
|
|
18
|
+
- @ledgerhq/cryptoassets@13.35.0-nightly.20251213023821
|
|
19
|
+
- @ledgerhq/errors@6.28.0-nightly.20251213023821
|
|
20
|
+
- @ledgerhq/live-env@2.23.0-nightly.20251213023821
|
|
21
|
+
- @ledgerhq/devices@8.8.0-nightly.20251213023821
|
|
22
|
+
- @ledgerhq/types-cryptoassets@7.31.0-nightly.20251213023821
|
|
23
|
+
- @ledgerhq/live-network@2.1.3-nightly.20251213023821
|
|
22
24
|
|
|
23
25
|
## 0.15.1
|
|
24
26
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAE1E,OAAO,KAAK,EAAE,cAAc,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAS/E,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAG1C,OAAO,EAAE,UAAU,EAAE,MAAM,qCAAqC,CAAC;AACjE,OAA0B,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAE1E,OAAO,KAAK,EAAE,cAAc,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAS/E,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAG1C,OAAO,EAAE,UAAU,EAAE,MAAM,qCAAqC,CAAC;AACjE,OAA0B,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAC;AAGjE,wBAAgB,mBAAmB,CAAC,aAAa,EAAE,aAAa,CAAC,aAAa,CAAC,GAAG,cAAc,CAa/F;AAED,wBAAgB,kBAAkB,CAChC,aAAa,EAAE,aAAa,CAAC,aAAa,CAAC,GAC1C,aAAa,CAAC,WAAW,EAAE,cAAc,EAAE,iBAAiB,CAAC,CA4B/D;AAED,wBAAgB,aAAa,CAC3B,aAAa,EAAE,aAAa,CAAC,aAAa,CAAC,EAC3C,UAAU,EAAE,UAAU,CAAC,iBAAiB,CAAC;;;EAO1C"}
|
package/lib/bridge/index.js
CHANGED
|
@@ -17,6 +17,7 @@ const postSyncPatch_1 = require("../postSyncPatch");
|
|
|
17
17
|
const broadcast_1 = require("../broadcast");
|
|
18
18
|
const hw_getAddress_1 = __importDefault(require("../hw-getAddress"));
|
|
19
19
|
const config_1 = __importDefault(require("../config"));
|
|
20
|
+
const validateAddress_1 = require("../validateAddress");
|
|
20
21
|
function buildCurrencyBridge(signerContext) {
|
|
21
22
|
const getAddress = (0, hw_getAddress_1.default)(signerContext);
|
|
22
23
|
const scanAccounts = (0, jsHelpers_1.makeScanAccounts)({
|
|
@@ -54,6 +55,7 @@ function buildAccountBridge(signerContext) {
|
|
|
54
55
|
assignToAccountRaw: serialization_1.assignToAccountRaw,
|
|
55
56
|
assignFromAccountRaw: serialization_1.assignFromAccountRaw,
|
|
56
57
|
getSerializedAddressParameters: jsHelpers_1.getSerializedAddressParameters,
|
|
58
|
+
validateAddress: validateAddress_1.validateAddress,
|
|
57
59
|
};
|
|
58
60
|
}
|
|
59
61
|
exports.buildAccountBridge = buildAccountBridge;
|
package/lib/bridge/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":";;;;;;AAAA,yEAMmD;AAGnD,0GAAkF;AAElF,oDAA4E;AAC5E,kEAA+D;AAC/D,uFAAoF;AACpF,8DAA2D;AAC3D,4DAAyD;AACzD,wDAAyD;AACzD,oDAAsD;AACtD,oDAAiD;AAEjD,4CAAyC;AACzC,qEAAwC;AAExC,uDAAiE;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":";;;;;;AAAA,yEAMmD;AAGnD,0GAAkF;AAElF,oDAA4E;AAC5E,kEAA+D;AAC/D,uFAAoF;AACpF,8DAA2D;AAC3D,4DAAyD;AACzD,wDAAyD;AACzD,oDAAsD;AACtD,oDAAiD;AAEjD,4CAAyC;AACzC,qEAAwC;AAExC,uDAAiE;AACjE,wDAAqD;AAErD,SAAgB,mBAAmB,CAAC,aAA2C;IAC7E,MAAM,UAAU,GAAG,IAAA,uBAAQ,EAAC,aAAa,CAAC,CAAC;IAC3C,MAAM,YAAY,GAAG,IAAA,4BAAgB,EAAC;QACpC,eAAe,EAAE,IAAA,qCAAmB,EAAC,aAAa,CAAC;QACnD,YAAY,EAAE,IAAA,2BAAiB,EAAC,UAAU,CAAC;QAC3C,QAAQ,EAAE,6BAAa;KACxB,CAAC,CAAC;IAEH,OAAO;QACL,YAAY;QACZ,OAAO,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC;QACzB,OAAO,EAAE,GAAG,EAAE,GAAE,CAAC;KAClB,CAAC;AACJ,CAAC;AAbD,kDAaC;AAED,SAAgB,kBAAkB,CAChC,aAA2C;IAE3C,MAAM,IAAI,GAAG,IAAA,oBAAQ,EAAC;QACpB,eAAe,EAAE,IAAA,qCAAmB,EAAC,aAAa,CAAC;QACnD,QAAQ,EAAE,6BAAa;KACxB,CAAC,CAAC;IAEH,MAAM,UAAU,GAAG,IAAA,uBAAQ,EAAC,aAAa,CAAC,CAAC;IAE3C,MAAM,OAAO,GAAG,IAAA,oCAAwB,EAAC,IAAA,2BAAiB,EAAC,UAAU,CAAC,CAAC,CAAC;IAExE,OAAO;QACL,oBAAoB,EAApB,2CAAoB;QACpB,iBAAiB,EAAjB,qCAAiB;QACjB,iBAAiB,EAAjB,6BAAiB;QACjB,oBAAoB,EAApB,2CAAoB;QACpB,kBAAkB,EAAlB,uCAAkB;QAClB,IAAI;QACJ,OAAO;QACP,aAAa,EAAE,IAAA,kCAAkB,EAAC,aAAa,CAAC;QAChD,gBAAgB,EAAE,GAAG,EAAE;YACrB,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;QACvD,CAAC;QACD,SAAS,EAAT,qBAAS;QACT,kBAAkB,EAAlB,kCAAkB;QAClB,oBAAoB,EAApB,oCAAoB;QACpB,8BAA8B,EAA9B,0CAA8B;QAC9B,eAAe,EAAf,iCAAe;KAChB,CAAC;AACJ,CAAC;AA9BD,gDA8BC;AAED,SAAgB,aAAa,CAC3B,aAA2C,EAC3C,UAAyC;IAEzC,gBAAiB,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IAC5C,OAAO;QACL,cAAc,EAAE,mBAAmB,CAAC,aAAa,CAAC;QAClD,aAAa,EAAE,kBAAkB,CAAC,aAAa,CAAC;KACjD,CAAC;AACJ,CAAC;AATD,sCASC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validateAddress.d.ts","sourceRoot":"","sources":["../src/validateAddress.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mCAAmC,EAAE,MAAM,sBAAsB,CAAC;AAG3E,wBAAsB,eAAe,CACnC,OAAO,EAAE,MAAM,EACf,UAAU,EAAE,OAAO,CAAC,mCAAmC,CAAC,GACvD,OAAO,CAAC,OAAO,CAAC,CAMlB"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.validateAddress = void 0;
|
|
4
|
+
const logic_1 = require("./logic");
|
|
5
|
+
async function validateAddress(address, parameters) {
|
|
6
|
+
if (!parameters.networkId) {
|
|
7
|
+
throw new Error("Missing networkId parameter on address validation for Cardano");
|
|
8
|
+
}
|
|
9
|
+
return (0, logic_1.isValidAddress)(address, parameters.networkId);
|
|
10
|
+
}
|
|
11
|
+
exports.validateAddress = validateAddress;
|
|
12
|
+
//# sourceMappingURL=validateAddress.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validateAddress.js","sourceRoot":"","sources":["../src/validateAddress.ts"],"names":[],"mappings":";;;AACA,mCAAyC;AAElC,KAAK,UAAU,eAAe,CACnC,OAAe,EACf,UAAwD;IAExD,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;QAC1B,MAAM,IAAI,KAAK,CAAC,+DAA+D,CAAC,CAAC;IACnF,CAAC;IAED,OAAO,IAAA,sBAAc,EAAC,OAAO,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC;AACvD,CAAC;AATD,0CASC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAE1E,OAAO,KAAK,EAAE,cAAc,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAS/E,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAG1C,OAAO,EAAE,UAAU,EAAE,MAAM,qCAAqC,CAAC;AACjE,OAA0B,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAE1E,OAAO,KAAK,EAAE,cAAc,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAS/E,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAG1C,OAAO,EAAE,UAAU,EAAE,MAAM,qCAAqC,CAAC;AACjE,OAA0B,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAC;AAGjE,wBAAgB,mBAAmB,CAAC,aAAa,EAAE,aAAa,CAAC,aAAa,CAAC,GAAG,cAAc,CAa/F;AAED,wBAAgB,kBAAkB,CAChC,aAAa,EAAE,aAAa,CAAC,aAAa,CAAC,GAC1C,aAAa,CAAC,WAAW,EAAE,cAAc,EAAE,iBAAiB,CAAC,CA4B/D;AAED,wBAAgB,aAAa,CAC3B,aAAa,EAAE,aAAa,CAAC,aAAa,CAAC,EAC3C,UAAU,EAAE,UAAU,CAAC,iBAAiB,CAAC;;;EAO1C"}
|
package/lib-es/bridge/index.js
CHANGED
|
@@ -11,6 +11,7 @@ import { postSyncPatch } from "../postSyncPatch";
|
|
|
11
11
|
import { broadcast } from "../broadcast";
|
|
12
12
|
import resolver from "../hw-getAddress";
|
|
13
13
|
import cardanoCoinConfig from "../config";
|
|
14
|
+
import { validateAddress } from "../validateAddress";
|
|
14
15
|
export function buildCurrencyBridge(signerContext) {
|
|
15
16
|
const getAddress = resolver(signerContext);
|
|
16
17
|
const scanAccounts = makeScanAccounts({
|
|
@@ -47,6 +48,7 @@ export function buildAccountBridge(signerContext) {
|
|
|
47
48
|
assignToAccountRaw,
|
|
48
49
|
assignFromAccountRaw,
|
|
49
50
|
getSerializedAddressParameters,
|
|
51
|
+
validateAddress,
|
|
50
52
|
};
|
|
51
53
|
}
|
|
52
54
|
export function createBridges(signerContext, coinConfig) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,8BAA8B,EAC9B,iBAAiB,EACjB,wBAAwB,EACxB,gBAAgB,EAChB,QAAQ,GACT,MAAM,2CAA2C,CAAC;AAGnD,OAAO,iBAAiB,MAAM,mDAAmD,CAAC;AAElF,OAAO,EAAE,kBAAkB,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAC5E,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,EAAE,oBAAoB,EAAE,MAAM,8CAA8C,CAAC;AACpF,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAEjD,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,QAAQ,MAAM,kBAAkB,CAAC;AAExC,OAAO,iBAAwC,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,8BAA8B,EAC9B,iBAAiB,EACjB,wBAAwB,EACxB,gBAAgB,EAChB,QAAQ,GACT,MAAM,2CAA2C,CAAC;AAGnD,OAAO,iBAAiB,MAAM,mDAAmD,CAAC;AAElF,OAAO,EAAE,kBAAkB,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAC5E,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,EAAE,oBAAoB,EAAE,MAAM,8CAA8C,CAAC;AACpF,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAEjD,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,QAAQ,MAAM,kBAAkB,CAAC;AAExC,OAAO,iBAAwC,MAAM,WAAW,CAAC;AACjE,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAErD,MAAM,UAAU,mBAAmB,CAAC,aAA2C;IAC7E,MAAM,UAAU,GAAG,QAAQ,CAAC,aAAa,CAAC,CAAC;IAC3C,MAAM,YAAY,GAAG,gBAAgB,CAAC;QACpC,eAAe,EAAE,mBAAmB,CAAC,aAAa,CAAC;QACnD,YAAY,EAAE,iBAAiB,CAAC,UAAU,CAAC;QAC3C,QAAQ,EAAE,aAAa;KACxB,CAAC,CAAC;IAEH,OAAO;QACL,YAAY;QACZ,OAAO,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC;QACzB,OAAO,EAAE,GAAG,EAAE,GAAE,CAAC;KAClB,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,kBAAkB,CAChC,aAA2C;IAE3C,MAAM,IAAI,GAAG,QAAQ,CAAC;QACpB,eAAe,EAAE,mBAAmB,CAAC,aAAa,CAAC;QACnD,QAAQ,EAAE,aAAa;KACxB,CAAC,CAAC;IAEH,MAAM,UAAU,GAAG,QAAQ,CAAC,aAAa,CAAC,CAAC;IAE3C,MAAM,OAAO,GAAG,wBAAwB,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC,CAAC;IAExE,OAAO;QACL,oBAAoB;QACpB,iBAAiB;QACjB,iBAAiB;QACjB,oBAAoB;QACpB,kBAAkB;QAClB,IAAI;QACJ,OAAO;QACP,aAAa,EAAE,kBAAkB,CAAC,aAAa,CAAC;QAChD,gBAAgB,EAAE,GAAG,EAAE;YACrB,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;QACvD,CAAC;QACD,SAAS;QACT,kBAAkB;QAClB,oBAAoB;QACpB,8BAA8B;QAC9B,eAAe;KAChB,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,aAAa,CAC3B,aAA2C,EAC3C,UAAyC;IAEzC,iBAAiB,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IAC5C,OAAO;QACL,cAAc,EAAE,mBAAmB,CAAC,aAAa,CAAC;QAClD,aAAa,EAAE,kBAAkB,CAAC,aAAa,CAAC;KACjD,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validateAddress.d.ts","sourceRoot":"","sources":["../src/validateAddress.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mCAAmC,EAAE,MAAM,sBAAsB,CAAC;AAG3E,wBAAsB,eAAe,CACnC,OAAO,EAAE,MAAM,EACf,UAAU,EAAE,OAAO,CAAC,mCAAmC,CAAC,GACvD,OAAO,CAAC,OAAO,CAAC,CAMlB"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { isValidAddress } from "./logic";
|
|
2
|
+
export async function validateAddress(address, parameters) {
|
|
3
|
+
if (!parameters.networkId) {
|
|
4
|
+
throw new Error("Missing networkId parameter on address validation for Cardano");
|
|
5
|
+
}
|
|
6
|
+
return isValidAddress(address, parameters.networkId);
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=validateAddress.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validateAddress.js","sourceRoot":"","sources":["../src/validateAddress.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAEzC,MAAM,CAAC,KAAK,UAAU,eAAe,CACnC,OAAe,EACf,UAAwD;IAExD,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;QAC1B,MAAM,IAAI,KAAK,CAAC,+DAA+D,CAAC,CAAC;IACnF,CAAC;IAED,OAAO,cAAc,CAAC,OAAO,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC;AACvD,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ledgerhq/coin-cardano",
|
|
3
|
-
"version": "0.16.0-nightly.
|
|
3
|
+
"version": "0.16.0-nightly.20251213023821",
|
|
4
4
|
"description": "Ledger Cardano Coin integration",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"Ledger",
|
|
@@ -59,15 +59,15 @@
|
|
|
59
59
|
"invariant": "^2.2.2",
|
|
60
60
|
"lodash": "^4.17.21",
|
|
61
61
|
"rxjs": "7.8.2",
|
|
62
|
-
"@ledgerhq/coin-framework": "^6.11.0-nightly.
|
|
63
|
-
"@ledgerhq/cryptoassets": "^13.35.0-nightly.
|
|
64
|
-
"@ledgerhq/devices": "8.8.0-nightly.
|
|
65
|
-
"@ledgerhq/errors": "^6.28.0-nightly.
|
|
66
|
-
"@ledgerhq/live-env": "^2.23.0-nightly.
|
|
67
|
-
"@ledgerhq/live-network": "^2.1.3-nightly.
|
|
62
|
+
"@ledgerhq/coin-framework": "^6.11.0-nightly.20251213023821",
|
|
63
|
+
"@ledgerhq/cryptoassets": "^13.35.0-nightly.20251213023821",
|
|
64
|
+
"@ledgerhq/devices": "8.8.0-nightly.20251213023821",
|
|
65
|
+
"@ledgerhq/errors": "^6.28.0-nightly.20251213023821",
|
|
66
|
+
"@ledgerhq/live-env": "^2.23.0-nightly.20251213023821",
|
|
67
|
+
"@ledgerhq/live-network": "^2.1.3-nightly.20251213023821",
|
|
68
68
|
"@ledgerhq/logs": "^6.13.0",
|
|
69
|
-
"@ledgerhq/types-cryptoassets": "^7.31.0-nightly.
|
|
70
|
-
"@ledgerhq/types-live": "^6.91.0-nightly.
|
|
69
|
+
"@ledgerhq/types-cryptoassets": "^7.31.0-nightly.20251213023821",
|
|
70
|
+
"@ledgerhq/types-live": "^6.91.0-nightly.20251213023821"
|
|
71
71
|
},
|
|
72
72
|
"devDependencies": {
|
|
73
73
|
"@types/invariant": "^2.2.2",
|
package/src/bridge/index.ts
CHANGED
|
@@ -22,6 +22,7 @@ import { broadcast } from "../broadcast";
|
|
|
22
22
|
import resolver from "../hw-getAddress";
|
|
23
23
|
import { CoinConfig } from "@ledgerhq/coin-framework/lib/config";
|
|
24
24
|
import cardanoCoinConfig, { CardanoCoinConfig } from "../config";
|
|
25
|
+
import { validateAddress } from "../validateAddress";
|
|
25
26
|
|
|
26
27
|
export function buildCurrencyBridge(signerContext: SignerContext<CardanoSigner>): CurrencyBridge {
|
|
27
28
|
const getAddress = resolver(signerContext);
|
|
@@ -66,6 +67,7 @@ export function buildAccountBridge(
|
|
|
66
67
|
assignToAccountRaw,
|
|
67
68
|
assignFromAccountRaw,
|
|
68
69
|
getSerializedAddressParameters,
|
|
70
|
+
validateAddress,
|
|
69
71
|
};
|
|
70
72
|
}
|
|
71
73
|
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { isValidAddress } from "./logic";
|
|
2
|
+
import { validateAddress } from "./validateAddress";
|
|
3
|
+
|
|
4
|
+
jest.mock("./logic");
|
|
5
|
+
|
|
6
|
+
describe("validateAddress", () => {
|
|
7
|
+
const mockedIsValidAddress = jest.mocked(isValidAddress);
|
|
8
|
+
|
|
9
|
+
beforeEach(() => {
|
|
10
|
+
mockedIsValidAddress.mockClear();
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
it("should throw an error when currency parameters miss networkId", async () => {
|
|
14
|
+
await expect(validateAddress("some random address", {})).rejects.toThrow(
|
|
15
|
+
"Missing networkId parameter on address validation for Cardano",
|
|
16
|
+
);
|
|
17
|
+
|
|
18
|
+
expect(mockedIsValidAddress).toHaveBeenCalledTimes(0);
|
|
19
|
+
});
|
|
20
|
+
|
|
21
|
+
it.each([true, false])(
|
|
22
|
+
"should correcly call isAddressValid and return the correct result (%s)",
|
|
23
|
+
async (expectedValue: boolean) => {
|
|
24
|
+
mockedIsValidAddress.mockReturnValueOnce(expectedValue);
|
|
25
|
+
|
|
26
|
+
const result = await validateAddress("some random address", { networkId: 1 });
|
|
27
|
+
expect(result).toEqual(expectedValue);
|
|
28
|
+
|
|
29
|
+
expect(mockedIsValidAddress).toHaveBeenCalledTimes(1);
|
|
30
|
+
expect(mockedIsValidAddress).toHaveBeenCalledWith("some random address", 1);
|
|
31
|
+
},
|
|
32
|
+
);
|
|
33
|
+
});
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { AddressValidationCurrencyParameters } from "@ledgerhq/types-live";
|
|
2
|
+
import { isValidAddress } from "./logic";
|
|
3
|
+
|
|
4
|
+
export async function validateAddress(
|
|
5
|
+
address: string,
|
|
6
|
+
parameters: Partial<AddressValidationCurrencyParameters>,
|
|
7
|
+
): Promise<boolean> {
|
|
8
|
+
if (!parameters.networkId) {
|
|
9
|
+
throw new Error("Missing networkId parameter on address validation for Cardano");
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
return isValidAddress(address, parameters.networkId);
|
|
13
|
+
}
|
package/tsconfig.json
CHANGED