@ledgerhq/coin-internet_computer 1.9.0-nightly.5 → 1.9.0-nightly.7

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 (106) hide show
  1. package/.turbo/turbo-build.log +1 -1
  2. package/CHANGELOG.md +22 -0
  3. package/lib/api/api.d.ts +6 -11
  4. package/lib/api/api.d.ts.map +1 -1
  5. package/lib/api/api.js +84 -64
  6. package/lib/api/api.js.map +1 -1
  7. package/lib/bridge/bridgeHelpers/account.d.ts.map +1 -1
  8. package/lib/bridge/bridgeHelpers/account.js +52 -33
  9. package/lib/bridge/bridgeHelpers/account.js.map +1 -1
  10. package/lib/bridge/bridgeHelpers/addresses.d.ts +0 -6
  11. package/lib/bridge/bridgeHelpers/addresses.d.ts.map +1 -1
  12. package/lib/bridge/bridgeHelpers/addresses.js +1 -29
  13. package/lib/bridge/bridgeHelpers/addresses.js.map +1 -1
  14. package/lib/bridge/broadcast.d.ts.map +1 -1
  15. package/lib/bridge/broadcast.js +22 -6
  16. package/lib/bridge/broadcast.js.map +1 -1
  17. package/lib/bridge/getTransactionStatus.d.ts.map +1 -1
  18. package/lib/bridge/getTransactionStatus.js +4 -3
  19. package/lib/bridge/getTransactionStatus.js.map +1 -1
  20. package/lib/bridge/prepareTransaction.d.ts.map +1 -1
  21. package/lib/bridge/prepareTransaction.js +2 -1
  22. package/lib/bridge/prepareTransaction.js.map +1 -1
  23. package/lib/bridge/signOperation.d.ts +2 -2
  24. package/lib/bridge/signOperation.d.ts.map +1 -1
  25. package/lib/bridge/signOperation.js +44 -13
  26. package/lib/bridge/signOperation.js.map +1 -1
  27. package/lib/consts.d.ts +2 -0
  28. package/lib/consts.d.ts.map +1 -1
  29. package/lib/consts.js +8 -1
  30. package/lib/consts.js.map +1 -1
  31. package/lib/hw-signMessage.d.ts.map +1 -1
  32. package/lib/hw-signMessage.js +1 -2
  33. package/lib/hw-signMessage.js.map +1 -1
  34. package/lib/types/signer.d.ts +1 -1
  35. package/lib/types/signer.d.ts.map +1 -1
  36. package/lib-es/api/api.d.ts +6 -11
  37. package/lib-es/api/api.d.ts.map +1 -1
  38. package/lib-es/api/api.js +81 -60
  39. package/lib-es/api/api.js.map +1 -1
  40. package/lib-es/bridge/bridgeHelpers/account.d.ts.map +1 -1
  41. package/lib-es/bridge/bridgeHelpers/account.js +52 -33
  42. package/lib-es/bridge/bridgeHelpers/account.js.map +1 -1
  43. package/lib-es/bridge/bridgeHelpers/addresses.d.ts +0 -6
  44. package/lib-es/bridge/bridgeHelpers/addresses.d.ts.map +1 -1
  45. package/lib-es/bridge/bridgeHelpers/addresses.js +0 -23
  46. package/lib-es/bridge/bridgeHelpers/addresses.js.map +1 -1
  47. package/lib-es/bridge/broadcast.d.ts.map +1 -1
  48. package/lib-es/bridge/broadcast.js +19 -6
  49. package/lib-es/bridge/broadcast.js.map +1 -1
  50. package/lib-es/bridge/getTransactionStatus.d.ts.map +1 -1
  51. package/lib-es/bridge/getTransactionStatus.js +2 -1
  52. package/lib-es/bridge/getTransactionStatus.js.map +1 -1
  53. package/lib-es/bridge/prepareTransaction.d.ts.map +1 -1
  54. package/lib-es/bridge/prepareTransaction.js +2 -1
  55. package/lib-es/bridge/prepareTransaction.js.map +1 -1
  56. package/lib-es/bridge/signOperation.d.ts +2 -2
  57. package/lib-es/bridge/signOperation.d.ts.map +1 -1
  58. package/lib-es/bridge/signOperation.js +41 -13
  59. package/lib-es/bridge/signOperation.js.map +1 -1
  60. package/lib-es/consts.d.ts +2 -0
  61. package/lib-es/consts.d.ts.map +1 -1
  62. package/lib-es/consts.js +3 -0
  63. package/lib-es/consts.js.map +1 -1
  64. package/lib-es/hw-signMessage.d.ts.map +1 -1
  65. package/lib-es/hw-signMessage.js +1 -2
  66. package/lib-es/hw-signMessage.js.map +1 -1
  67. package/lib-es/types/signer.d.ts +1 -1
  68. package/lib-es/types/signer.d.ts.map +1 -1
  69. package/package.json +5 -11
  70. package/src/api/api.ts +126 -71
  71. package/src/bridge/bridgeHelpers/account.ts +70 -43
  72. package/src/bridge/bridgeHelpers/addresses.ts +0 -25
  73. package/src/bridge/broadcast.ts +31 -6
  74. package/src/bridge/getTransactionStatus.ts +2 -1
  75. package/src/bridge/prepareTransaction.ts +2 -1
  76. package/src/bridge/signOperation.ts +68 -18
  77. package/src/consts.ts +10 -0
  78. package/src/hw-signMessage.ts +1 -6
  79. package/src/types/signer.ts +1 -1
  80. package/lib/bridge/bridgeHelpers/icpRosetta/index.d.ts +0 -30
  81. package/lib/bridge/bridgeHelpers/icpRosetta/index.d.ts.map +0 -1
  82. package/lib/bridge/bridgeHelpers/icpRosetta/index.js +0 -88
  83. package/lib/bridge/bridgeHelpers/icpRosetta/index.js.map +0 -1
  84. package/lib/bridge/bridgeHelpers/icpRosetta/types.d.ts +0 -145
  85. package/lib/bridge/bridgeHelpers/icpRosetta/types.d.ts.map +0 -1
  86. package/lib/bridge/bridgeHelpers/icpRosetta/types.js +0 -3
  87. package/lib/bridge/bridgeHelpers/icpRosetta/types.js.map +0 -1
  88. package/lib/bridge/bridgeHelpers/icpRosetta/utils.d.ts +0 -17
  89. package/lib/bridge/bridgeHelpers/icpRosetta/utils.d.ts.map +0 -1
  90. package/lib/bridge/bridgeHelpers/icpRosetta/utils.js +0 -155
  91. package/lib/bridge/bridgeHelpers/icpRosetta/utils.js.map +0 -1
  92. package/lib-es/bridge/bridgeHelpers/icpRosetta/index.d.ts +0 -30
  93. package/lib-es/bridge/bridgeHelpers/icpRosetta/index.d.ts.map +0 -1
  94. package/lib-es/bridge/bridgeHelpers/icpRosetta/index.js +0 -76
  95. package/lib-es/bridge/bridgeHelpers/icpRosetta/index.js.map +0 -1
  96. package/lib-es/bridge/bridgeHelpers/icpRosetta/types.d.ts +0 -145
  97. package/lib-es/bridge/bridgeHelpers/icpRosetta/types.d.ts.map +0 -1
  98. package/lib-es/bridge/bridgeHelpers/icpRosetta/types.js +0 -2
  99. package/lib-es/bridge/bridgeHelpers/icpRosetta/types.js.map +0 -1
  100. package/lib-es/bridge/bridgeHelpers/icpRosetta/utils.d.ts +0 -17
  101. package/lib-es/bridge/bridgeHelpers/icpRosetta/utils.d.ts.map +0 -1
  102. package/lib-es/bridge/bridgeHelpers/icpRosetta/utils.js +0 -123
  103. package/lib-es/bridge/bridgeHelpers/icpRosetta/utils.js.map +0 -1
  104. package/src/bridge/bridgeHelpers/icpRosetta/index.ts +0 -154
  105. package/src/bridge/bridgeHelpers/icpRosetta/types.ts +0 -166
  106. package/src/bridge/bridgeHelpers/icpRosetta/utils.ts +0 -151
@@ -1,25 +1,2 @@
1
- import { log } from "@ledgerhq/logs";
2
- import BigNumber from "bignumber.js";
3
- import { MAX_MEMO_VALUE } from "../../consts";
4
- import { fetchBalances } from "../../api";
5
1
  export const getAddress = (a) => ({ address: a.freshAddress, derivationPath: a.freshAddressPath });
6
- export async function validateAddress(address) {
7
- try {
8
- const res = await fetchBalances(address);
9
- if (!res.balances)
10
- throw Error(res.details?.error_message);
11
- return { isValid: true };
12
- }
13
- catch (e) {
14
- log("error", e.message ?? "Failed to validate address");
15
- return { isValid: false };
16
- }
17
- }
18
- export function validateMemo(memo) {
19
- const res = BigNumber(memo ?? 0);
20
- if (res.isNaN() || res.lt(0) || res.gt(BigNumber(MAX_MEMO_VALUE))) {
21
- return { isValid: false };
22
- }
23
- return { isValid: true };
24
- }
25
2
  //# sourceMappingURL=addresses.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"addresses.js","sourceRoot":"","sources":["../../../src/bridge/bridgeHelpers/addresses.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAErC,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAE1C,MAAM,CAAC,MAAM,UAAU,GAAG,CACxB,CAAU,EAIV,EAAE,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,YAAY,EAAE,cAAc,EAAE,CAAC,CAAC,gBAAgB,EAAE,CAAC,CAAC;AAEvE,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,OAAe;IACnD,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,aAAa,CAAC,OAAO,CAAC,CAAC;QACzC,IAAI,CAAC,GAAG,CAAC,QAAQ;YAAE,MAAM,KAAK,CAAC,GAAG,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;QAC3D,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IAC3B,CAAC;IAAC,OAAO,CAAM,EAAE,CAAC;QAChB,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC,OAAO,IAAI,4BAA4B,CAAC,CAAC;QACxD,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;IAC5B,CAAC;AACH,CAAC;AAED,MAAM,UAAU,YAAY,CAAC,IAAa;IACxC,MAAM,GAAG,GAAG,SAAS,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC;IAEjC,IAAI,GAAG,CAAC,KAAK,EAAE,IAAI,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,EAAE,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,EAAE,CAAC;QAClE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;IAC5B,CAAC;IAED,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;AAC3B,CAAC"}
1
+ {"version":3,"file":"addresses.js","sourceRoot":"","sources":["../../../src/bridge/bridgeHelpers/addresses.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,UAAU,GAAG,CACxB,CAAU,EAIV,EAAE,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,YAAY,EAAE,cAAc,EAAE,CAAC,CAAC,gBAAgB,EAAE,CAAC,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"broadcast.d.ts","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErD,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAEvC,eAAO,MAAM,SAAS,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,WAAW,CAU7D,CAAC"}
1
+ {"version":3,"file":"broadcast.d.ts","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErD,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAqBvC,eAAO,MAAM,SAAS,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,WAAW,CAgB7D,CAAC"}
@@ -1,8 +1,21 @@
1
- import { broadcastTxn } from "./bridgeHelpers/icpRosetta";
2
- export const broadcast = async ({ signedOperation: { signature, operation }, }) => {
3
- // log("debug", "[broadcast] start fn");
4
- await broadcastTxn(signature);
5
- const result = { ...operation };
6
- return result;
1
+ import { broadcastTxn } from "../api";
2
+ import { log } from "@ledgerhq/logs";
3
+ import invariant from "invariant";
4
+ import { MAINNET_LEDGER_CANISTER_ID } from "../consts";
5
+ // Type guard to validate rawData shape
6
+ function isBroadcastRawData(data) {
7
+ return (typeof data === "object" &&
8
+ data !== null &&
9
+ "encodedSignedCallBlob" in data &&
10
+ typeof data.encodedSignedCallBlob === "string");
11
+ }
12
+ // Main broadcast function for handling Internet Computer transactions
13
+ export const broadcast = async ({ signedOperation: { operation, rawData }, }) => {
14
+ log("debug", "[broadcast] Internet Computer transaction broadcast initiated");
15
+ // Validate rawData with type guard
16
+ invariant(isBroadcastRawData(rawData), "[ICP](broadcast) Invalid rawData format");
17
+ invariant(operation.extra, "[ICP](broadcast) Missing operation extra");
18
+ await broadcastTxn(Buffer.from(rawData.encodedSignedCallBlob, "hex"), MAINNET_LEDGER_CANISTER_ID, "call");
19
+ return operation;
7
20
  };
8
21
  //# sourceMappingURL=broadcast.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAG1D,MAAM,CAAC,MAAM,SAAS,GAA4C,KAAK,EAAE,EACvE,eAAe,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,GAC1C,EAAE,EAAE;IACH,wCAAwC;IAExC,MAAM,YAAY,CAAC,SAAS,CAAC,CAAC;IAE9B,MAAM,MAAM,GAAG,EAAE,GAAG,SAAS,EAAE,CAAC;IAEhC,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC"}
1
+ {"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,SAAS,MAAM,WAAW,CAAC;AAClC,OAAO,EAAE,0BAA0B,EAAE,MAAM,WAAW,CAAC;AAOvD,uCAAuC;AACvC,SAAS,kBAAkB,CAAC,IAAa;IACvC,OAAO,CACL,OAAO,IAAI,KAAK,QAAQ;QACxB,IAAI,KAAK,IAAI;QACb,uBAAuB,IAAI,IAAI;QAC/B,OAAQ,IAAY,CAAC,qBAAqB,KAAK,QAAQ,CACxD,CAAC;AACJ,CAAC;AAED,sEAAsE;AACtE,MAAM,CAAC,MAAM,SAAS,GAA4C,KAAK,EAAE,EACvE,eAAe,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,GACxC,EAAE,EAAE;IACH,GAAG,CAAC,OAAO,EAAE,+DAA+D,CAAC,CAAC;IAE9E,mCAAmC;IACnC,SAAS,CAAC,kBAAkB,CAAC,OAAO,CAAC,EAAE,yCAAyC,CAAC,CAAC;IAClF,SAAS,CAAC,SAAS,CAAC,KAAK,EAAE,0CAA0C,CAAC,CAAC;IAEvE,MAAM,YAAY,CAChB,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,qBAAqB,EAAE,KAAK,CAAC,EACjD,0BAA0B,EAC1B,MAAM,CACP,CAAC;IAEF,OAAO,SAAS,CAAC;AACnB,CAAC,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"getTransactionStatus.d.ts","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErD,OAAO,EAAE,WAAW,EAAqB,MAAM,UAAU,CAAC;AAG1D,eAAO,MAAM,oBAAoB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,sBAAsB,CA6DnF,CAAC"}
1
+ {"version":3,"file":"getTransactionStatus.d.ts","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAGrD,OAAO,EAAE,WAAW,EAAqB,MAAM,UAAU,CAAC;AAG1D,eAAO,MAAM,oBAAoB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,sBAAsB,CA6DnF,CAAC"}
@@ -1,5 +1,6 @@
1
1
  import { AmountRequired, InvalidAddress, InvalidAddressBecauseDestinationIsAlsoSource, NotEnoughBalance, RecipientRequired, } from "@ledgerhq/errors";
2
- import { getAddress, validateAddress, validateMemo } from "./bridgeHelpers/addresses";
2
+ import { getAddress } from "./bridgeHelpers/addresses";
3
+ import { validateAddress, validateMemo } from "@zondax/ledger-live-icp/utils";
3
4
  import { InvalidMemoICP } from "../errors";
4
5
  export const getTransactionStatus = async (account, transaction) => {
5
6
  const errors = {};
@@ -1 +1 @@
1
- {"version":3,"file":"getTransactionStatus.js","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,cAAc,EACd,cAAc,EACd,4CAA4C,EAC5C,gBAAgB,EAChB,iBAAiB,GAClB,MAAM,kBAAkB,CAAC;AAG1B,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAEtF,OAAO,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAE3C,MAAM,CAAC,MAAM,oBAAoB,GAAuD,KAAK,EAC3F,OAAO,EACP,WAAW,EACX,EAAE;IACF,MAAM,MAAM,GAAgC,EAAE,CAAC;IAC/C,MAAM,QAAQ,GAAkC,EAAE,CAAC;IAEnD,MAAM,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;IAC5B,MAAM,EAAE,OAAO,EAAE,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC;IACxC,MAAM,EAAE,SAAS,EAAE,YAAY,EAAE,GAAG,WAAW,CAAC;IAChD,IAAI,EAAE,MAAM,EAAE,GAAG,WAAW,CAAC;IAE7B,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,MAAM,CAAC,SAAS,GAAG,IAAI,iBAAiB,EAAE,CAAC;IAC7C,CAAC;SAAM,IAAI,CAAC,CAAC,MAAM,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;QACvD,MAAM,CAAC,SAAS,GAAG,IAAI,cAAc,CAAC,EAAE,EAAE;YACxC,YAAY,EAAE,OAAO,CAAC,QAAQ,CAAC,IAAI;SACpC,CAAC,CAAC;IACL,CAAC;SAAM,IAAI,SAAS,CAAC,WAAW,EAAE,KAAK,OAAO,CAAC,WAAW,EAAE,EAAE,CAAC;QAC7D,MAAM,CAAC,SAAS,GAAG,IAAI,4CAA4C,EAAE,CAAC;IACxE,CAAC;IAED,IAAI,CAAC,CAAC,MAAM,eAAe,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;QAC9C,MAAM,CAAC,MAAM,GAAG,IAAI,cAAc,CAAC,EAAE,EAAE;YACrC,YAAY,EAAE,OAAO,CAAC,QAAQ,CAAC,IAAI;SACpC,CAAC,CAAC;IACL,CAAC;IAED,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,CAAC;QAC5C,MAAM,CAAC,WAAW,GAAG,IAAI,cAAc,EAAE,CAAC;IAC5C,CAAC;IAED,2EAA2E;IAC3E,MAAM,aAAa,GAAG,WAAW,CAAC,IAAI,CAAC;IAEvC,IAAI,UAAqB,CAAC;IAE1B,IAAI,YAAY,EAAE,CAAC;QACjB,UAAU,GAAG,OAAO,CAAC,gBAAgB,CAAC;QACtC,MAAM,GAAG,UAAU,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QACzC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,UAAU,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC;YAC5C,MAAM,CAAC,MAAM,GAAG,IAAI,gBAAgB,EAAE,CAAC;QACzC,CAAC;IACH,CAAC;SAAM,CAAC;QACN,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACxC,IAAI,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YACjB,MAAM,CAAC,MAAM,GAAG,IAAI,cAAc,EAAE,CAAC;QACvC,CAAC;aAAM,IAAI,UAAU,CAAC,EAAE,CAAC,OAAO,CAAC,gBAAgB,CAAC,EAAE,CAAC;YACnD,MAAM,CAAC,MAAM,GAAG,IAAI,gBAAgB,EAAE,CAAC;QACzC,CAAC;IACH,CAAC;IAED,oDAAoD;IAEpD,OAAO;QACL,MAAM;QACN,QAAQ;QACR,aAAa;QACb,MAAM;QACN,UAAU;KACX,CAAC;AACJ,CAAC,CAAC"}
1
+ {"version":3,"file":"getTransactionStatus.js","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"prepareTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAGvC,eAAO,MAAM,kBAAkB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,oBAAoB,CAuB/E,CAAC"}
1
+ {"version":3,"file":"prepareTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAIvC,eAAO,MAAM,kBAAkB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,oBAAoB,CAuB/E,CAAC"}
@@ -1,4 +1,5 @@
1
- import { getAddress, validateAddress } from "./bridgeHelpers/addresses";
1
+ import { getAddress } from "./bridgeHelpers/addresses";
2
+ import { validateAddress } from "@zondax/ledger-live-icp";
2
3
  export const prepareTransaction = async (account, transaction) => {
3
4
  // log("debug", "[prepareTransaction] start fn");
4
5
  const { address } = getAddress(account);
@@ -1 +1 @@
1
- {"version":3,"file":"prepareTransaction.js","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAExE,MAAM,CAAC,MAAM,kBAAkB,GAAqD,KAAK,EACvF,OAAO,EACP,WAAW,EACX,EAAE;IACF,iDAAiD;IAEjD,MAAM,EAAE,OAAO,EAAE,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC;IACxC,MAAM,EAAE,SAAS,EAAE,GAAG,WAAW,CAAC;IAElC,IAAI,MAAM,GAAG,WAAW,CAAC,MAAM,CAAC;IAChC,IAAI,SAAS,IAAI,OAAO,EAAE,CAAC;QACzB,gEAAgE;QAEhE,IAAI,CAAC,MAAM,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,IAAI,CAAC,MAAM,eAAe,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;YAC3F,IAAI,WAAW,CAAC,YAAY,EAAE,CAAC;gBAC7B,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;gBAC1D,OAAO,EAAE,GAAG,WAAW,EAAE,MAAM,EAAE,CAAC;YACpC,CAAC;QACH,CAAC;IACH,CAAC;IAED,kDAAkD;IAClD,OAAO,WAAW,CAAC;AACrB,CAAC,CAAC"}
1
+ {"version":3,"file":"prepareTransaction.js","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAE1D,MAAM,CAAC,MAAM,kBAAkB,GAAqD,KAAK,EACvF,OAAO,EACP,WAAW,EACX,EAAE;IACF,iDAAiD;IAEjD,MAAM,EAAE,OAAO,EAAE,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC;IACxC,MAAM,EAAE,SAAS,EAAE,GAAG,WAAW,CAAC;IAElC,IAAI,MAAM,GAAG,WAAW,CAAC,MAAM,CAAC;IAChC,IAAI,SAAS,IAAI,OAAO,EAAE,CAAC;QACzB,gEAAgE;QAEhE,IAAI,CAAC,MAAM,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,IAAI,CAAC,MAAM,eAAe,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;YAC3F,IAAI,WAAW,CAAC,YAAY,EAAE,CAAC;gBAC7B,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;gBAC1D,OAAO,EAAE,GAAG,WAAW,EAAE,MAAM,EAAE,CAAC;YACpC,CAAC;QACH,CAAC;IACH,CAAC;IAED,kDAAkD;IAClD,OAAO,WAAW,CAAC;AACrB,CAAC,CAAC"}
@@ -1,6 +1,6 @@
1
- import { Account, AccountBridge } from "@ledgerhq/types-live";
1
+ import { AccountBridge } from "@ledgerhq/types-live";
2
2
  import { Transaction } from "../types";
3
3
  import { SignerContext } from "@ledgerhq/coin-framework/signer";
4
4
  import { ICPSigner } from "../types";
5
- export declare const buildSignOperation: (signerContext: SignerContext<ICPSigner>) => AccountBridge<Transaction, Account>["signOperation"];
5
+ export declare const buildSignOperation: (signerContext: SignerContext<ICPSigner>) => AccountBridge<Transaction>["signOperation"];
6
6
  //# sourceMappingURL=signOperation.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"signOperation.d.ts","sourceRoot":"","sources":["../../src/bridge/signOperation.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAS9D,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AACvC,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAGrC,eAAO,MAAM,kBAAkB,kBACb,cAAc,SAAS,CAAC,KAAG,cAAc,WAAW,EAAE,OAAO,CAAC,CAAC,eAAe,CA0C1F,CAAC"}
1
+ {"version":3,"file":"signOperation.d.ts","sourceRoot":"","sources":["../../src/bridge/signOperation.ts"],"names":[],"mappings":"AACA,OAAO,EAAW,aAAa,EAAY,MAAM,sBAAsB,CAAC;AAUxE,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AACvC,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AA8BrC,eAAO,MAAM,kBAAkB,kBACb,cAAc,SAAS,CAAC,KAAG,cAAc,WAAW,CAAC,CAAC,eAAe,CAgEjF,CAAC"}
@@ -1,35 +1,63 @@
1
1
  import { Observable } from "rxjs";
2
2
  import { getAddress } from "./bridgeHelpers/addresses";
3
- import { getTxnExpirationDate, getTxnMetadata, getUnsignedTransaction, signICPTransaction, } from "./bridgeHelpers/icpRosetta";
3
+ import { createUnsignedSendTransaction, hashTransaction, pubkeyToDer, } from "@zondax/ledger-live-icp/utils";
4
+ import { Cbor } from "@zondax/ledger-live-icp/agent";
4
5
  import { buildOptimisticOperation } from "./buildOptimisticOperation";
5
6
  import { getPath } from "../common-logic";
7
+ import { log } from "@ledgerhq/logs";
8
+ import invariant from "invariant";
9
+ const signICPTransaction = async (unsignedTxn, derivationPath, signerContext, account, deviceId) => {
10
+ const blob = Cbor.encode({ content: unsignedTxn });
11
+ log("debug", "[signICPTransaction] blob", Buffer.from(blob).toString("hex"));
12
+ const signatures = await signerContext(deviceId, signer => signer.sign(derivationPath, Buffer.from(blob)));
13
+ invariant(signatures.signatureRS, "[ICP](signICPTransaction) Signature not found");
14
+ invariant(account.xpub, "[ICP](signICPTransaction) Account xpub is required");
15
+ return {
16
+ signature: Buffer.from(signatures.signatureRS).toString("hex"),
17
+ callBody: {
18
+ content: unsignedTxn,
19
+ sender_pubkey: pubkeyToDer(account.xpub),
20
+ sender_sig: signatures.signatureRS,
21
+ },
22
+ };
23
+ };
6
24
  export const buildSignOperation = (signerContext) => ({ account, transaction, deviceId }) => new Observable(o => {
7
25
  async function main() {
26
+ log("debug", "[signOperation] icp start fn");
27
+ log("debug", "[signOperation] transaction", transaction);
8
28
  const { xpub } = account;
29
+ invariant(xpub, "[ICP](signOperation) Account xpub is required");
9
30
  const { derivationPath } = getAddress(account);
10
- const { unsignedTxn, payloads } = await getUnsignedTransaction(transaction, account);
31
+ const { unsignedTransaction, transferRawRequest } = createUnsignedSendTransaction(transaction, xpub);
11
32
  o.next({
12
33
  type: "device-signature-requested",
13
34
  });
14
- const { signedTxn } = await signICPTransaction({
15
- signerContext,
16
- deviceId,
17
- unsignedTxn,
18
- path: getPath(derivationPath),
19
- payloads,
20
- pubkey: xpub ?? "",
21
- });
35
+ let signature = "";
36
+ let encodedSignedCallBlob = "";
37
+ const res = await signICPTransaction(unsignedTransaction, getPath(derivationPath), signerContext, account, deviceId);
38
+ signature = res.signature;
39
+ encodedSignedCallBlob = Buffer.from(Cbor.encode(res.callBody)).toString("hex");
40
+ invariant(signature, "[ICP](signOperation) Signature not found");
22
41
  o.next({
23
42
  type: "device-signature-granted",
24
43
  });
25
- const { hash } = await getTxnMetadata(signedTxn);
44
+ const hash = hashTransaction({
45
+ from: account.freshAddress,
46
+ to: transaction.recipient,
47
+ amount: transferRawRequest.amount.e8s,
48
+ fee: transferRawRequest.fee.e8s,
49
+ memo: transferRawRequest.memo,
50
+ created_at_time: transferRawRequest.created_at_time[0]["timestamp_nanos"],
51
+ });
26
52
  const operation = await buildOptimisticOperation(account, transaction, hash);
27
53
  o.next({
28
54
  type: "signed",
29
55
  signedOperation: {
30
56
  operation,
31
- signature: signedTxn,
32
- expirationDate: getTxnExpirationDate(unsignedTxn),
57
+ signature,
58
+ rawData: {
59
+ encodedSignedCallBlob,
60
+ },
33
61
  },
34
62
  });
35
63
  }
@@ -1 +1 @@
1
- {"version":3,"file":"signOperation.js","sourceRoot":"","sources":["../../src/bridge/signOperation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAElC,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACvD,OAAO,EACL,oBAAoB,EACpB,cAAc,EACd,sBAAsB,EACtB,kBAAkB,GACnB,MAAM,4BAA4B,CAAC;AACpC,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AAItE,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAE1C,MAAM,CAAC,MAAM,kBAAkB,GAC7B,CAAC,aAAuC,EAAwD,EAAE,CAClG,CAAC,EAAE,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,EAAE,EAAE,CACrC,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE;IACjB,KAAK,UAAU,IAAI;QACjB,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC;QACzB,MAAM,EAAE,cAAc,EAAE,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC;QAC/C,MAAM,EAAE,WAAW,EAAE,QAAQ,EAAE,GAAG,MAAM,sBAAsB,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;QAErF,CAAC,CAAC,IAAI,CAAC;YACL,IAAI,EAAE,4BAA4B;SACnC,CAAC,CAAC;QAEH,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,kBAAkB,CAAC;YAC7C,aAAa;YACb,QAAQ;YACR,WAAW;YACX,IAAI,EAAE,OAAO,CAAC,cAAc,CAAC;YAC7B,QAAQ;YACR,MAAM,EAAE,IAAI,IAAI,EAAE;SACnB,CAAC,CAAC;QAEH,CAAC,CAAC,IAAI,CAAC;YACL,IAAI,EAAE,0BAA0B;SACjC,CAAC,CAAC;QAEH,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,cAAc,CAAC,SAAS,CAAC,CAAC;QACjD,MAAM,SAAS,GAAG,MAAM,wBAAwB,CAAC,OAAO,EAAE,WAAW,EAAE,IAAI,CAAC,CAAC;QAE7E,CAAC,CAAC,IAAI,CAAC;YACL,IAAI,EAAE,QAAQ;YACd,eAAe,EAAE;gBACf,SAAS;gBACT,SAAS,EAAE,SAAS;gBACpB,cAAc,EAAE,oBAAoB,CAAC,WAAW,CAAC;aAClD;SACF,CAAC,CAAC;IACL,CAAC;IAED,IAAI,EAAE,CAAC,IAAI,CACT,GAAG,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,EAClB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAChB,CAAC;AACJ,CAAC,CAAC,CAAC"}
1
+ {"version":3,"file":"signOperation.js","sourceRoot":"","sources":["../../src/bridge/signOperation.ts"],"names":[],"mappings":"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"}
@@ -3,4 +3,6 @@ export declare const ICP_BLK_NAME_ROSETTA = "Internet Computer";
3
3
  export declare const ICP_NET_ID_ROSETTA = "00000000000000020101";
4
4
  export declare const ICP_FEES = 10000;
5
5
  export declare const MAX_MEMO_VALUE: number;
6
+ export declare const FETCH_TXNS_LIMIT = 100;
7
+ export { MAINNET_GOVERNANCE_CANISTER_ID, MAINNET_LEDGER_CANISTER_ID, MAINNET_INDEX_CANISTER_ID, ICP_NETWORK_URL, } from "@zondax/ledger-live-icp/neurons";
6
8
  //# sourceMappingURL=consts.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"consts.d.ts","sourceRoot":"","sources":["../src/consts.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,iBAAiB,IAAI,CAAC;AAGnC,eAAO,MAAM,oBAAoB,sBAAsB,CAAC;AACxD,eAAO,MAAM,kBAAkB,yBAAyB,CAAC;AAGzD,eAAO,MAAM,QAAQ,QAAM,CAAC;AAG5B,eAAO,MAAM,cAAc,QAA0B,CAAC"}
1
+ {"version":3,"file":"consts.d.ts","sourceRoot":"","sources":["../src/consts.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,iBAAiB,IAAI,CAAC;AAGnC,eAAO,MAAM,oBAAoB,sBAAsB,CAAC;AACxD,eAAO,MAAM,kBAAkB,yBAAyB,CAAC;AAGzD,eAAO,MAAM,QAAQ,QAAM,CAAC;AAG5B,eAAO,MAAM,cAAc,QAA0B,CAAC;AAGtD,eAAO,MAAM,gBAAgB,MAAM,CAAC;AAEpC,OAAO,EACL,8BAA8B,EAC9B,0BAA0B,EAC1B,yBAAyB,EACzB,eAAe,GAChB,MAAM,iCAAiC,CAAC"}
package/lib-es/consts.js CHANGED
@@ -6,4 +6,7 @@ export const ICP_NET_ID_ROSETTA = "00000000000000020101";
6
6
  export const ICP_FEES = 1e4;
7
7
  // Max Memo value on ICP network
8
8
  export const MAX_MEMO_VALUE = Number.MAX_SAFE_INTEGER;
9
+ // API limits
10
+ export const FETCH_TXNS_LIMIT = 100;
11
+ export { MAINNET_GOVERNANCE_CANISTER_ID, MAINNET_LEDGER_CANISTER_ID, MAINNET_INDEX_CANISTER_ID, ICP_NETWORK_URL, } from "@zondax/ledger-live-icp/neurons";
9
12
  //# sourceMappingURL=consts.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"consts.js","sourceRoot":"","sources":["../src/consts.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,CAAC;AAEnC,kBAAkB;AAClB,MAAM,CAAC,MAAM,oBAAoB,GAAG,mBAAmB,CAAC;AACxD,MAAM,CAAC,MAAM,kBAAkB,GAAG,sBAAsB,CAAC;AAEzD,eAAe;AACf,MAAM,CAAC,MAAM,QAAQ,GAAG,GAAG,CAAC;AAE5B,gCAAgC;AAChC,MAAM,CAAC,MAAM,cAAc,GAAG,MAAM,CAAC,gBAAgB,CAAC"}
1
+ {"version":3,"file":"consts.js","sourceRoot":"","sources":["../src/consts.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,CAAC;AAEnC,kBAAkB;AAClB,MAAM,CAAC,MAAM,oBAAoB,GAAG,mBAAmB,CAAC;AACxD,MAAM,CAAC,MAAM,kBAAkB,GAAG,sBAAsB,CAAC;AAEzD,eAAe;AACf,MAAM,CAAC,MAAM,QAAQ,GAAG,GAAG,CAAC;AAE5B,gCAAgC;AAChC,MAAM,CAAC,MAAM,cAAc,GAAG,MAAM,CAAC,gBAAgB,CAAC;AAEtD,aAAa;AACb,MAAM,CAAC,MAAM,gBAAgB,GAAG,GAAG,CAAC;AAEpC,OAAO,EACL,8BAA8B,EAC9B,0BAA0B,EAC1B,yBAAyB,EACzB,eAAe,GAChB,MAAM,iCAAiC,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"hw-signMessage.d.ts","sourceRoot":"","sources":["../src/hw-signMessage.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AACpC,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAO3D,eAAO,MAAM,WAAW,kBACN,cAAc,SAAS,CAAC,gBACvB,MAAM,WAAW,OAAO,eAAe,UAAU;;;;;;;EA2BjE,CAAC"}
1
+ {"version":3,"file":"hw-signMessage.d.ts","sourceRoot":"","sources":["../src/hw-signMessage.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AACpC,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAO3D,eAAO,MAAM,WAAW,kBACN,cAAc,SAAS,CAAC,gBACvB,MAAM,WAAW,OAAO,eAAe,UAAU;;;;;;;EAuBjE,CAAC"}
@@ -1,6 +1,5 @@
1
1
  import { log } from "@ledgerhq/logs";
2
2
  import { getBufferFromString } from "./common-logic/utils";
3
- import { ICP_SEND_TXN_TYPE } from "./consts";
4
3
  function bufferToArrayBuffer(buffer) {
5
4
  const sig = buffer.buffer.slice(buffer.byteOffset, buffer.byteOffset + buffer.byteLength);
6
5
  return Buffer.from(sig);
@@ -12,7 +11,7 @@ export const signMessage = (signerContext) => async (deviceId, account, { messag
12
11
  if (typeof message !== "string")
13
12
  throw new Error("Message must be a string");
14
13
  const { r } = await signerContext(deviceId, async (signer) => {
15
- const r = await signer.sign(account.freshAddressPath, getBufferFromString(message), ICP_SEND_TXN_TYPE);
14
+ const r = await signer.sign(account.freshAddressPath, getBufferFromString(message));
16
15
  return { r };
17
16
  });
18
17
  if (!r.signatureRS) {
@@ -1 +1 @@
1
- {"version":3,"file":"hw-signMessage.js","sourceRoot":"","sources":["../src/hw-signMessage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAK7C,SAAS,mBAAmB,CAAC,MAAc;IACzC,MAAM,GAAG,GAAG,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IAC1F,OAAO,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAC1B,CAAC;AAED,MAAM,CAAC,MAAM,WAAW,GACtB,CAAC,aAAuC,EAAE,EAAE,CAC5C,KAAK,EAAE,QAAgB,EAAE,OAAgB,EAAE,EAAE,OAAO,EAAc,EAAE,EAAE;IACpE,GAAG,CAAC,OAAO,EAAE,2BAA2B,CAAC,CAAC;IAE1C,IAAI,CAAC,OAAO;QAAE,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IACzD,IAAI,OAAO,OAAO,KAAK,QAAQ;QAAE,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;IAE7E,MAAM,EAAE,CAAC,EAAE,GAAG,MAAM,aAAa,CAAC,QAAQ,EAAE,KAAK,EAAC,MAAM,EAAC,EAAE;QACzD,MAAM,CAAC,GAAG,MAAM,MAAM,CAAC,IAAI,CACzB,OAAO,CAAC,gBAAgB,EACxB,mBAAmB,CAAC,OAAO,CAAC,EAC5B,iBAAiB,CAClB,CAAC;QACF,OAAO,EAAE,CAAC,EAAE,CAAC;IACf,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;QACnB,MAAM,KAAK,CAAC,gBAAgB,CAAC,CAAC;IAChC,CAAC;IAED,OAAO;QACL,GAAG,EAAE;YACH,CAAC,EAAE,EAAE;YACL,CAAC,EAAE,EAAE;YACL,CAAC,EAAE,CAAC;SACL;QACD,SAAS,EAAE,mBAAmB,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;KAC9D,CAAC;AACJ,CAAC,CAAC"}
1
+ {"version":3,"file":"hw-signMessage.js","sourceRoot":"","sources":["../src/hw-signMessage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAK3D,SAAS,mBAAmB,CAAC,MAAc;IACzC,MAAM,GAAG,GAAG,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IAC1F,OAAO,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAC1B,CAAC;AAED,MAAM,CAAC,MAAM,WAAW,GACtB,CAAC,aAAuC,EAAE,EAAE,CAC5C,KAAK,EAAE,QAAgB,EAAE,OAAgB,EAAE,EAAE,OAAO,EAAc,EAAE,EAAE;IACpE,GAAG,CAAC,OAAO,EAAE,2BAA2B,CAAC,CAAC;IAE1C,IAAI,CAAC,OAAO;QAAE,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IACzD,IAAI,OAAO,OAAO,KAAK,QAAQ;QAAE,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;IAE7E,MAAM,EAAE,CAAC,EAAE,GAAG,MAAM,aAAa,CAAC,QAAQ,EAAE,KAAK,EAAC,MAAM,EAAC,EAAE;QACzD,MAAM,CAAC,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,OAAO,CAAC,CAAC,CAAC;QACpF,OAAO,EAAE,CAAC,EAAE,CAAC;IACf,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;QACnB,MAAM,KAAK,CAAC,gBAAgB,CAAC,CAAC;IAChC,CAAC;IAED,OAAO;QACL,GAAG,EAAE;YACH,CAAC,EAAE,EAAE;YACL,CAAC,EAAE,EAAE;YACL,CAAC,EAAE,CAAC;SACL;QACD,SAAS,EAAE,mBAAmB,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;KAC9D,CAAC;AACJ,CAAC,CAAC"}
@@ -16,6 +16,6 @@ export type ICPGetAddrResponse = {
16
16
  export interface ICPSigner {
17
17
  showAddressAndPubKey(path: string): Promise<ICPGetAddrResponse>;
18
18
  getAddressAndPubKey(path: string): Promise<ICPGetAddrResponse>;
19
- sign(path: string, message: Buffer, txtype: number): Promise<ICPSignature>;
19
+ sign(path: string, message: Buffer): Promise<ICPSignature>;
20
20
  }
21
21
  //# sourceMappingURL=signer.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"signer.d.ts","sourceRoot":"","sources":["../../src/types/signer.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,YAAY,GAAG;IACzB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG;IAC/B,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,MAAM,WAAW,SAAS;IACxB,oBAAoB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAAC;IAChE,mBAAmB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAAC;IAC/D,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC;CAC5E"}
1
+ {"version":3,"file":"signer.d.ts","sourceRoot":"","sources":["../../src/types/signer.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,YAAY,GAAG;IACzB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG;IAC/B,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,MAAM,WAAW,SAAS;IACxB,oBAAoB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAAC;IAChE,mBAAmB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAAC;IAC/D,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC;CAC5D"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ledgerhq/coin-internet_computer",
3
- "version": "1.9.0-nightly.5",
3
+ "version": "1.9.0-nightly.7",
4
4
  "description": "Ledger Internet Computer integration",
5
5
  "keywords": [
6
6
  "Ledger",
@@ -84,24 +84,18 @@
84
84
  },
85
85
  "license": "Apache-2.0",
86
86
  "dependencies": {
87
- "@dfinity/agent": "^0.21.0",
88
- "@dfinity/candid": "^0.21.0",
89
- "@dfinity/principal": "^0.15.6",
90
- "big-integer": "^1.6.51",
87
+ "@zondax/ledger-live-icp": "1.3.2",
91
88
  "bignumber.js": "^9.1.2",
92
89
  "expect": "^27.4.6",
93
90
  "invariant": "^2.2.2",
94
91
  "lodash": "^4.17.21",
95
92
  "rxjs": "^7.8.1",
96
- "simple-cbor": "^0.4.1",
97
- "@ledgerhq/coin-framework": "^6.7.0-nightly.5",
98
- "@ledgerhq/cryptoassets": "^13.31.0-nightly.5",
93
+ "@ledgerhq/coin-framework": "^6.7.0-nightly.7",
94
+ "@ledgerhq/cryptoassets": "^13.31.0-nightly.7",
99
95
  "@ledgerhq/devices": "8.6.2-nightly.0",
100
96
  "@ledgerhq/errors": "^6.27.0-nightly.0",
101
- "@ledgerhq/live-env": "^2.19.0-nightly.1",
102
- "@ledgerhq/live-network": "^2.0.20-nightly.2",
103
97
  "@ledgerhq/logs": "^6.13.0",
104
- "@ledgerhq/types-live": "^6.87.0-nightly.3"
98
+ "@ledgerhq/types-live": "^6.87.0-nightly.5"
105
99
  },
106
100
  "devDependencies": {
107
101
  "@types/invariant": "^2.2.2",
package/src/api/api.ts CHANGED
@@ -1,92 +1,147 @@
1
1
  import { log } from "@ledgerhq/logs";
2
- import { AxiosRequestConfig, AxiosResponse } from "axios";
3
- import { getEnv } from "@ledgerhq/live-env";
4
- import network from "@ledgerhq/live-network/network";
5
- import { ICP_BLK_NAME_ROSETTA, ICP_NET_ID_ROSETTA } from "../consts";
6
2
  import {
7
- ICPRosettaBlockHeightResponse,
8
- ICPRosettaGetBalancesResponse,
9
- ICPRosettaGetTxnsHistoryResponse,
10
- } from "../bridge/bridgeHelpers/icpRosetta/types";
3
+ FETCH_TXNS_LIMIT,
4
+ MAINNET_INDEX_CANISTER_ID,
5
+ MAINNET_LEDGER_CANISTER_ID,
6
+ ICP_NETWORK_URL,
7
+ } from "../consts";
11
8
 
12
- const getICPURL = (path?: string): string => {
13
- const baseUrl = getEnv("API_ICP_ENDPOINT");
14
- if (!baseUrl) throw new Error("API base URL not available");
15
-
16
- return `${baseUrl}${path ? path : ""}`;
17
- };
18
-
19
- const ICPFetchWrapper = async <T>(path: string, body: any) => {
20
- const url = getICPURL(path);
9
+ import {
10
+ ledgerIdlFactory,
11
+ indexIdlFactory,
12
+ getCanisterIdlFunc,
13
+ Principal,
14
+ encodeCanisterIdlFunc,
15
+ decodeCanisterIdlFunc,
16
+ GetAccountIdentifierTransactionsResponse,
17
+ TransactionWithId,
18
+ } from "@zondax/ledger-live-icp";
19
+ import BigNumber from "bignumber.js";
20
+ import { fromNullable } from "@zondax/ledger-live-icp/utils";
21
+ import { getAgent } from "@zondax/ledger-live-icp/agent";
22
+ import invariant from "invariant";
21
23
 
22
- // We force data to this way as network func is not using the correct param type. Changing that func will generate errors in other implementations
23
- const opts: AxiosRequestConfig = {
24
- method: "POST",
25
- data: body,
26
- url,
24
+ export const fetchBlockHeight = async (): Promise<BigNumber> => {
25
+ const canisterId = Principal.fromText(MAINNET_LEDGER_CANISTER_ID);
26
+ const queryBlocksRawRequest = {
27
+ start: BigInt(0),
28
+ length: BigInt(1),
27
29
  };
28
- const rawResponse = await network(opts);
29
- if (rawResponse && rawResponse.data && rawResponse.data.details?.error_message) {
30
- log("error", rawResponse.data.details?.error_message);
31
- }
32
30
 
33
- // We force data to this way as network func is not using the correct param type. Changing that func will generate errors in other implementations
34
- const { data } = rawResponse as AxiosResponse<T>;
31
+ const queryBlocksIdlFunc = getCanisterIdlFunc(ledgerIdlFactory, "query_blocks");
32
+ const queryBlocksargs = encodeCanisterIdlFunc(queryBlocksIdlFunc, [queryBlocksRawRequest]);
35
33
 
36
- log("http", url);
37
- return data;
38
- };
34
+ const agent = await getAgent(ICP_NETWORK_URL);
35
+ const blockHeightRes = await agent.query(canisterId, {
36
+ arg: queryBlocksargs,
37
+ methodName: "query_blocks",
38
+ });
39
39
 
40
- export const getICPRosettaNetworkIdentifier = () => {
41
- return {
42
- network_identifier: {
43
- blockchain: ICP_BLK_NAME_ROSETTA,
44
- network: ICP_NET_ID_ROSETTA,
45
- },
46
- };
47
- };
40
+ invariant(blockHeightRes.status === "replied", "[ICP](fetchBlockHeight) Query failed");
48
41
 
49
- export const fetchBlockHeight = async (): Promise<ICPRosettaBlockHeightResponse> => {
50
- const data = await ICPFetchWrapper<ICPRosettaBlockHeightResponse>(
51
- "network/status",
52
- getICPRosettaNetworkIdentifier(),
42
+ const decodedIdl = decodeCanisterIdlFunc<[{ chain_length: bigint }]>(
43
+ queryBlocksIdlFunc,
44
+ blockHeightRes.reply.arg,
53
45
  );
54
- return data;
46
+ const decoded = fromNullable(decodedIdl);
47
+ invariant(decoded, "[ICP](fetchBlockHeight) Decoding failed");
48
+
49
+ return BigNumber(decoded.chain_length.toString());
55
50
  };
56
51
 
57
- export const fetchBalances = async (accountId: string): Promise<ICPRosettaGetBalancesResponse> => {
58
- const body = {
59
- ...getICPRosettaNetworkIdentifier(),
60
- account_identifier: {
61
- address: accountId,
62
- metadata: {},
52
+ export const broadcastTxn = async (
53
+ payload: Buffer,
54
+ canisterId: string,
55
+ type: "call" | "read_state",
56
+ ) => {
57
+ log("debug", `[ICP] Broadcasting ${type} to ${canisterId}, body: ${payload.toString("hex")}`);
58
+ const res = await fetch(`${ICP_NETWORK_URL}/api/v3/canister/${canisterId}/${type}`, {
59
+ body: payload,
60
+ method: "POST",
61
+ headers: {
62
+ "Content-Type": "application/cbor",
63
63
  },
64
- };
65
- const data = await ICPFetchWrapper<ICPRosettaGetBalancesResponse>("account/balance", body);
66
- return data;
64
+ });
65
+
66
+ if (res.status === 200) {
67
+ return await res.arrayBuffer();
68
+ }
69
+
70
+ throw new Error(`Failed to broadcast transaction: ${res.text()}`);
67
71
  };
68
72
 
69
- export const fetchTxns = async (accountId: string): Promise<ICPRosettaGetTxnsHistoryResponse> => {
70
- const body = {
71
- ...getICPRosettaNetworkIdentifier(),
72
- account_identifier: {
73
- address: accountId,
74
- metadata: {},
75
- },
76
- };
77
- const data = await ICPFetchWrapper<ICPRosettaGetTxnsHistoryResponse>("search/transactions", body);
78
- return data;
73
+ export const fetchBalance = async (address: string): Promise<BigNumber> => {
74
+ const agent = await getAgent(ICP_NETWORK_URL);
75
+ const indexCanister = Principal.fromText(MAINNET_INDEX_CANISTER_ID);
76
+ const getBalanceIdlFunc = getCanisterIdlFunc(indexIdlFactory, "get_account_identifier_balance");
77
+ const getBalanceArgs = encodeCanisterIdlFunc(getBalanceIdlFunc, [address]);
78
+
79
+ const balanceRes = await agent.query(indexCanister, {
80
+ arg: getBalanceArgs,
81
+ methodName: "get_account_identifier_balance",
82
+ });
83
+
84
+ if (balanceRes.status !== "replied") {
85
+ log("debug", `[ICP](fetchBalance) Query failed: ${balanceRes.status}`);
86
+ return BigNumber(0);
87
+ }
88
+
89
+ const decodedBalance = decodeCanisterIdlFunc<[bigint]>(getBalanceIdlFunc, balanceRes.reply.arg);
90
+ const balance: bigint | undefined = fromNullable(decodedBalance);
91
+ if (!balance) {
92
+ return BigNumber(0);
93
+ }
94
+
95
+ return BigNumber(balance.toString());
79
96
  };
80
97
 
81
- export const constructionInvoke = async <TRequest, TResponse>(
82
- opts: TRequest,
83
- method: string,
84
- ): Promise<TResponse> => {
85
- const body: TRequest = {
86
- ...opts,
98
+ export const fetchTxns = async (
99
+ address: string,
100
+ startBlockHeight: bigint,
101
+ stopBlockHeight = BigInt(0),
102
+ ): Promise<TransactionWithId[]> => {
103
+ if (startBlockHeight <= stopBlockHeight) {
104
+ return [];
105
+ }
106
+
107
+ const agent = await getAgent(ICP_NETWORK_URL);
108
+ const canisterId = Principal.fromText(MAINNET_INDEX_CANISTER_ID);
109
+ const transactionsRawRequest = {
110
+ account_identifier: address,
111
+ start: [startBlockHeight],
112
+ max_results: BigInt(FETCH_TXNS_LIMIT),
87
113
  };
88
114
 
89
- const data = await ICPFetchWrapper<TResponse>(`construction/${method}`, body);
115
+ const getTransactionsIdlFunc = getCanisterIdlFunc(
116
+ indexIdlFactory,
117
+ "get_account_identifier_transactions",
118
+ );
119
+ const getTransactionsArgs = encodeCanisterIdlFunc(getTransactionsIdlFunc, [
120
+ transactionsRawRequest,
121
+ ]);
122
+
123
+ const transactionsRes = await agent.query(canisterId, {
124
+ arg: getTransactionsArgs,
125
+ methodName: "get_account_identifier_transactions",
126
+ });
127
+
128
+ invariant(transactionsRes.status === "replied", "[ICP](fetchTxns) Query failed");
129
+ const decodedTransactions = decodeCanisterIdlFunc<
130
+ [{ Ok: GetAccountIdentifierTransactionsResponse }]
131
+ >(getTransactionsIdlFunc, transactionsRes.reply.arg);
132
+
133
+ const response = fromNullable(decodedTransactions);
134
+ invariant(response, "[ICP](fetchTxns) Decoding failed");
135
+
136
+ if (response.Ok.transactions.length === 0) {
137
+ return [];
138
+ }
139
+
140
+ const nextTxns = await fetchTxns(
141
+ address,
142
+ response.Ok.transactions.at(-1)?.id ?? BigInt(0),
143
+ stopBlockHeight,
144
+ );
90
145
 
91
- return data;
146
+ return [...response.Ok.transactions, ...nextTxns];
92
147
  };