@sidhujag/sysweb3-keyring 1.0.547 → 1.0.548

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 (210) hide show
  1. package/package.json +2 -27
  2. package/coverage/clover.xml +0 -2875
  3. package/coverage/coverage-final.json +0 -29468
  4. package/coverage/lcov-report/base.css +0 -354
  5. package/coverage/lcov-report/block-navigation.js +0 -85
  6. package/coverage/lcov-report/favicon.png +0 -0
  7. package/coverage/lcov-report/index.html +0 -320
  8. package/coverage/lcov-report/prettify.css +0 -101
  9. package/coverage/lcov-report/prettify.js +0 -1008
  10. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  11. package/coverage/lcov-report/sorter.js +0 -191
  12. package/coverage/lcov-report/src/index.html +0 -276
  13. package/coverage/lcov-report/src/index.ts.html +0 -114
  14. package/coverage/lcov-report/src/initial-state.ts.html +0 -558
  15. package/coverage/lcov-report/src/keyring-manager.ts.html +0 -6279
  16. package/coverage/lcov-report/src/ledger/bitcoin_client/index.html +0 -178
  17. package/coverage/lcov-report/src/ledger/bitcoin_client/index.ts.html +0 -144
  18. package/coverage/lcov-report/src/ledger/bitcoin_client/lib/appClient.ts.html +0 -1560
  19. package/coverage/lcov-report/src/ledger/bitcoin_client/lib/bip32.ts.html +0 -276
  20. package/coverage/lcov-report/src/ledger/bitcoin_client/lib/buffertools.ts.html +0 -495
  21. package/coverage/lcov-report/src/ledger/bitcoin_client/lib/clientCommands.ts.html +0 -1138
  22. package/coverage/lcov-report/src/ledger/bitcoin_client/lib/index.html +0 -363
  23. package/coverage/lcov-report/src/ledger/bitcoin_client/lib/merkelizedPsbt.ts.html +0 -289
  24. package/coverage/lcov-report/src/ledger/bitcoin_client/lib/merkle.ts.html +0 -486
  25. package/coverage/lcov-report/src/ledger/bitcoin_client/lib/merkleMap.ts.html +0 -240
  26. package/coverage/lcov-report/src/ledger/bitcoin_client/lib/policy.ts.html +0 -342
  27. package/coverage/lcov-report/src/ledger/bitcoin_client/lib/psbtv2.ts.html +0 -2388
  28. package/coverage/lcov-report/src/ledger/bitcoin_client/lib/varint.ts.html +0 -453
  29. package/coverage/lcov-report/src/ledger/consts.ts.html +0 -177
  30. package/coverage/lcov-report/src/ledger/index.html +0 -216
  31. package/coverage/lcov-report/src/ledger/index.ts.html +0 -1371
  32. package/coverage/lcov-report/src/ledger/utils.ts.html +0 -102
  33. package/coverage/lcov-report/src/signers.ts.html +0 -591
  34. package/coverage/lcov-report/src/storage.ts.html +0 -198
  35. package/coverage/lcov-report/src/transactions/ethereum.ts.html +0 -5826
  36. package/coverage/lcov-report/src/transactions/index.html +0 -216
  37. package/coverage/lcov-report/src/transactions/index.ts.html +0 -93
  38. package/coverage/lcov-report/src/transactions/syscoin.ts.html +0 -1521
  39. package/coverage/lcov-report/src/trezor/index.html +0 -176
  40. package/coverage/lcov-report/src/trezor/index.ts.html +0 -2655
  41. package/coverage/lcov-report/src/types.ts.html +0 -1443
  42. package/coverage/lcov-report/src/utils/derivation-paths.ts.html +0 -486
  43. package/coverage/lcov-report/src/utils/index.html +0 -196
  44. package/coverage/lcov-report/src/utils/psbt.ts.html +0 -159
  45. package/coverage/lcov-report/test/helpers/constants.ts.html +0 -627
  46. package/coverage/lcov-report/test/helpers/index.html +0 -176
  47. package/coverage/lcov.info +0 -4832
  48. package/dist/package.json +0 -50
  49. package/examples/basic-usage.js +0 -140
  50. package/jest.config.js +0 -32
  51. package/readme.md +0 -201
  52. package/src/declare.d.ts +0 -7
  53. package/src/errorUtils.ts +0 -83
  54. package/src/hardware-wallet-manager.ts +0 -655
  55. package/src/index.ts +0 -12
  56. package/src/initial-state.ts +0 -108
  57. package/src/keyring-manager.ts +0 -2698
  58. package/src/ledger/bitcoin_client/index.ts +0 -19
  59. package/src/ledger/bitcoin_client/lib/appClient.ts +0 -405
  60. package/src/ledger/bitcoin_client/lib/bip32.ts +0 -61
  61. package/src/ledger/bitcoin_client/lib/buffertools.ts +0 -134
  62. package/src/ledger/bitcoin_client/lib/clientCommands.ts +0 -356
  63. package/src/ledger/bitcoin_client/lib/constants.ts +0 -12
  64. package/src/ledger/bitcoin_client/lib/merkelizedPsbt.ts +0 -65
  65. package/src/ledger/bitcoin_client/lib/merkle.ts +0 -136
  66. package/src/ledger/bitcoin_client/lib/merkleMap.ts +0 -49
  67. package/src/ledger/bitcoin_client/lib/policy.ts +0 -91
  68. package/src/ledger/bitcoin_client/lib/psbtv2.ts +0 -768
  69. package/src/ledger/bitcoin_client/lib/varint.ts +0 -120
  70. package/src/ledger/consts.ts +0 -3
  71. package/src/ledger/index.ts +0 -685
  72. package/src/ledger/types.ts +0 -74
  73. package/src/network-utils.ts +0 -99
  74. package/src/providers.ts +0 -345
  75. package/src/signers.ts +0 -158
  76. package/src/storage.ts +0 -63
  77. package/src/transactions/__tests__/integration.test.ts +0 -303
  78. package/src/transactions/__tests__/syscoin.test.ts +0 -409
  79. package/src/transactions/ethereum.ts +0 -2503
  80. package/src/transactions/index.ts +0 -2
  81. package/src/transactions/syscoin.ts +0 -542
  82. package/src/trezor/index.ts +0 -1050
  83. package/src/types.ts +0 -366
  84. package/src/utils/derivation-paths.ts +0 -133
  85. package/src/utils/psbt.ts +0 -24
  86. package/src/utils.ts +0 -191
  87. package/test/README.md +0 -158
  88. package/test/__mocks__/ledger-mock.js +0 -20
  89. package/test/__mocks__/trezor-mock.js +0 -75
  90. package/test/cleanup-summary.md +0 -167
  91. package/test/helpers/README.md +0 -78
  92. package/test/helpers/constants.ts +0 -79
  93. package/test/helpers/setup.ts +0 -714
  94. package/test/integration/import-validation.spec.ts +0 -588
  95. package/test/unit/hardware/ledger.spec.ts +0 -869
  96. package/test/unit/hardware/trezor.spec.ts +0 -828
  97. package/test/unit/keyring-manager/account-management.spec.ts +0 -970
  98. package/test/unit/keyring-manager/import-watchonly.spec.ts +0 -181
  99. package/test/unit/keyring-manager/import-wif.spec.ts +0 -126
  100. package/test/unit/keyring-manager/initialization.spec.ts +0 -782
  101. package/test/unit/keyring-manager/key-derivation.spec.ts +0 -996
  102. package/test/unit/keyring-manager/security.spec.ts +0 -505
  103. package/test/unit/keyring-manager/state-management.spec.ts +0 -375
  104. package/test/unit/network/network-management.spec.ts +0 -372
  105. package/test/unit/transactions/ethereum-transactions.spec.ts +0 -382
  106. package/test/unit/transactions/syscoin-transactions.spec.ts +0 -615
  107. package/tsconfig.json +0 -14
  108. /package/{dist/README.md → README.md} +0 -0
  109. /package/{dist/cjs → cjs}/errorUtils.js +0 -0
  110. /package/{dist/cjs → cjs}/errorUtils.js.map +0 -0
  111. /package/{dist/cjs → cjs}/hardware-wallet-manager.js +0 -0
  112. /package/{dist/cjs → cjs}/hardware-wallet-manager.js.map +0 -0
  113. /package/{dist/cjs → cjs}/index.js +0 -0
  114. /package/{dist/cjs → cjs}/index.js.map +0 -0
  115. /package/{dist/cjs → cjs}/initial-state.js +0 -0
  116. /package/{dist/cjs → cjs}/initial-state.js.map +0 -0
  117. /package/{dist/cjs → cjs}/keyring-manager.js +0 -0
  118. /package/{dist/cjs → cjs}/keyring-manager.js.map +0 -0
  119. /package/{dist/cjs → cjs}/ledger/bitcoin_client/index.js +0 -0
  120. /package/{dist/cjs → cjs}/ledger/bitcoin_client/index.js.map +0 -0
  121. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/appClient.js +0 -0
  122. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/appClient.js.map +0 -0
  123. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/bip32.js +0 -0
  124. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/bip32.js.map +0 -0
  125. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/buffertools.js +0 -0
  126. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/buffertools.js.map +0 -0
  127. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/clientCommands.js +0 -0
  128. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/clientCommands.js.map +0 -0
  129. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/constants.js +0 -0
  130. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/constants.js.map +0 -0
  131. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/merkelizedPsbt.js +0 -0
  132. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/merkelizedPsbt.js.map +0 -0
  133. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/merkle.js +0 -0
  134. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/merkle.js.map +0 -0
  135. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/merkleMap.js +0 -0
  136. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/merkleMap.js.map +0 -0
  137. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/policy.js +0 -0
  138. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/policy.js.map +0 -0
  139. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/psbtv2.js +0 -0
  140. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/psbtv2.js.map +0 -0
  141. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/varint.js +0 -0
  142. /package/{dist/cjs → cjs}/ledger/bitcoin_client/lib/varint.js.map +0 -0
  143. /package/{dist/cjs → cjs}/ledger/consts.js +0 -0
  144. /package/{dist/cjs → cjs}/ledger/consts.js.map +0 -0
  145. /package/{dist/cjs → cjs}/ledger/index.js +0 -0
  146. /package/{dist/cjs → cjs}/ledger/index.js.map +0 -0
  147. /package/{dist/cjs → cjs}/ledger/types.js +0 -0
  148. /package/{dist/cjs → cjs}/ledger/types.js.map +0 -0
  149. /package/{dist/cjs → cjs}/network-utils.js +0 -0
  150. /package/{dist/cjs → cjs}/network-utils.js.map +0 -0
  151. /package/{dist/cjs → cjs}/providers.js +0 -0
  152. /package/{dist/cjs → cjs}/providers.js.map +0 -0
  153. /package/{dist/cjs → cjs}/signers.js +0 -0
  154. /package/{dist/cjs → cjs}/signers.js.map +0 -0
  155. /package/{dist/cjs → cjs}/storage.js +0 -0
  156. /package/{dist/cjs → cjs}/storage.js.map +0 -0
  157. /package/{dist/cjs → cjs}/transactions/__tests__/integration.test.js +0 -0
  158. /package/{dist/cjs → cjs}/transactions/__tests__/integration.test.js.map +0 -0
  159. /package/{dist/cjs → cjs}/transactions/__tests__/syscoin.test.js +0 -0
  160. /package/{dist/cjs → cjs}/transactions/__tests__/syscoin.test.js.map +0 -0
  161. /package/{dist/cjs → cjs}/transactions/ethereum.js +0 -0
  162. /package/{dist/cjs → cjs}/transactions/ethereum.js.map +0 -0
  163. /package/{dist/cjs → cjs}/transactions/index.js +0 -0
  164. /package/{dist/cjs → cjs}/transactions/index.js.map +0 -0
  165. /package/{dist/cjs → cjs}/transactions/syscoin.js +0 -0
  166. /package/{dist/cjs → cjs}/transactions/syscoin.js.map +0 -0
  167. /package/{dist/cjs → cjs}/trezor/index.js +0 -0
  168. /package/{dist/cjs → cjs}/trezor/index.js.map +0 -0
  169. /package/{dist/cjs → cjs}/types.js +0 -0
  170. /package/{dist/cjs → cjs}/types.js.map +0 -0
  171. /package/{dist/cjs → cjs}/utils/derivation-paths.js +0 -0
  172. /package/{dist/cjs → cjs}/utils/derivation-paths.js.map +0 -0
  173. /package/{dist/cjs → cjs}/utils/psbt.js +0 -0
  174. /package/{dist/cjs → cjs}/utils/psbt.js.map +0 -0
  175. /package/{dist/cjs → cjs}/utils.js +0 -0
  176. /package/{dist/cjs → cjs}/utils.js.map +0 -0
  177. /package/{dist/types → types}/errorUtils.d.ts +0 -0
  178. /package/{dist/types → types}/hardware-wallet-manager.d.ts +0 -0
  179. /package/{dist/types → types}/index.d.ts +0 -0
  180. /package/{dist/types → types}/initial-state.d.ts +0 -0
  181. /package/{dist/types → types}/keyring-manager.d.ts +0 -0
  182. /package/{dist/types → types}/ledger/bitcoin_client/index.d.ts +0 -0
  183. /package/{dist/types → types}/ledger/bitcoin_client/lib/appClient.d.ts +0 -0
  184. /package/{dist/types → types}/ledger/bitcoin_client/lib/bip32.d.ts +0 -0
  185. /package/{dist/types → types}/ledger/bitcoin_client/lib/buffertools.d.ts +0 -0
  186. /package/{dist/types → types}/ledger/bitcoin_client/lib/clientCommands.d.ts +0 -0
  187. /package/{dist/types → types}/ledger/bitcoin_client/lib/constants.d.ts +0 -0
  188. /package/{dist/types → types}/ledger/bitcoin_client/lib/merkelizedPsbt.d.ts +0 -0
  189. /package/{dist/types → types}/ledger/bitcoin_client/lib/merkle.d.ts +0 -0
  190. /package/{dist/types → types}/ledger/bitcoin_client/lib/merkleMap.d.ts +0 -0
  191. /package/{dist/types → types}/ledger/bitcoin_client/lib/policy.d.ts +0 -0
  192. /package/{dist/types → types}/ledger/bitcoin_client/lib/psbtv2.d.ts +0 -0
  193. /package/{dist/types → types}/ledger/bitcoin_client/lib/varint.d.ts +0 -0
  194. /package/{dist/types → types}/ledger/consts.d.ts +0 -0
  195. /package/{dist/types → types}/ledger/index.d.ts +0 -0
  196. /package/{dist/types → types}/ledger/types.d.ts +0 -0
  197. /package/{dist/types → types}/network-utils.d.ts +0 -0
  198. /package/{dist/types → types}/providers.d.ts +0 -0
  199. /package/{dist/types → types}/signers.d.ts +0 -0
  200. /package/{dist/types → types}/storage.d.ts +0 -0
  201. /package/{dist/types → types}/transactions/__tests__/integration.test.d.ts +0 -0
  202. /package/{dist/types → types}/transactions/__tests__/syscoin.test.d.ts +0 -0
  203. /package/{dist/types → types}/transactions/ethereum.d.ts +0 -0
  204. /package/{dist/types → types}/transactions/index.d.ts +0 -0
  205. /package/{dist/types → types}/transactions/syscoin.d.ts +0 -0
  206. /package/{dist/types → types}/trezor/index.d.ts +0 -0
  207. /package/{dist/types → types}/types.d.ts +0 -0
  208. /package/{dist/types → types}/utils/derivation-paths.d.ts +0 -0
  209. /package/{dist/types → types}/utils/psbt.d.ts +0 -0
  210. /package/{dist/types → types}/utils.d.ts +0 -0
package/src/storage.ts DELETED
@@ -1,63 +0,0 @@
1
- import { sysweb3Di } from '@sidhujag/sysweb3-core';
2
- import CryptoJS from 'crypto-js';
3
-
4
- const storage = sysweb3Di.getStateStorageDb();
5
-
6
- // Simple async mutex implementation to prevent concurrent vault operations
7
- class AsyncMutex {
8
- private mutex = Promise.resolve();
9
-
10
- async runExclusive<T>(callback: () => Promise<T>): Promise<T> {
11
- const oldMutex = this.mutex;
12
-
13
- let release: () => void;
14
- this.mutex = new Promise((resolve) => {
15
- release = resolve;
16
- });
17
-
18
- await oldMutex;
19
- try {
20
- return await callback();
21
- } finally {
22
- release!();
23
- }
24
- }
25
- }
26
-
27
- const vaultMutex = new AsyncMutex();
28
-
29
- // Single vault for all networks - stores the mnemonic and can derive accounts for any slip44
30
- export const setEncryptedVault = async (decryptedVault: any, pwd: string) => {
31
- return vaultMutex.runExclusive(async () => {
32
- const encryptedVault = CryptoJS.AES.encrypt(
33
- JSON.stringify(decryptedVault),
34
- pwd
35
- );
36
-
37
- // Always use single 'vault' key for all networks
38
- await storage.set('vault', encryptedVault.toString());
39
- });
40
- };
41
-
42
- export const getDecryptedVault = async (pwd: string) => {
43
- return vaultMutex.runExclusive(async () => {
44
- // Always use single 'vault' key
45
- const vault = await storage.get('vault');
46
-
47
- if (!vault) {
48
- throw new Error('Vault not found');
49
- }
50
-
51
- const decryptedVault = CryptoJS.AES.decrypt(vault, pwd).toString(
52
- CryptoJS.enc.Utf8
53
- );
54
-
55
- if (!decryptedVault) {
56
- throw new Error(
57
- 'Failed to decrypt vault - invalid password or corrupted data'
58
- );
59
- }
60
-
61
- return JSON.parse(decryptedVault);
62
- });
63
- };
@@ -1,303 +0,0 @@
1
- import { KeyringAccountType } from '../../types';
2
- import { SyscoinTransactions } from '../syscoin';
3
-
4
- // Integration tests for the complete transaction flow
5
- describe('PSBT Transaction Flow Integration', () => {
6
- let syscoinTransactions: SyscoinTransactions;
7
- let mockSigner: any;
8
- let mockState: any;
9
- let mockLedger: any;
10
-
11
- beforeEach(() => {
12
- // Setup comprehensive mocks
13
- mockSigner = {
14
- hd: {
15
- Signer: { network: 'mainnet' },
16
- sign: jest.fn().mockResolvedValue('signed-psbt'),
17
- },
18
- main: {
19
- blockbookURL: 'https://blockbook.test',
20
- createPSBTFromRes: jest.fn().mockResolvedValue('unsigned-psbt'),
21
- assetAllocationSend: jest.fn().mockResolvedValue({
22
- psbt: 'unsigned-token-psbt',
23
- }),
24
- send: jest.fn().mockResolvedValue({
25
- extractTransaction: () => ({ getId: () => 'final-txid' }),
26
- }),
27
- },
28
- };
29
-
30
- mockState = {
31
- activeAccountId: 0,
32
- activeAccountType: KeyringAccountType.HDAccount,
33
- accounts: {
34
- [KeyringAccountType.HDAccount]: {
35
- 0: { xpub: 'xpub123', id: 0 },
36
- },
37
- },
38
- activeNetwork: { currency: 'sys', chainId: 57 },
39
- };
40
-
41
- mockLedger = {
42
- ledgerTransport: true,
43
- ledgerUtxoClient: {
44
- getMasterFingerprint: jest.fn().mockResolvedValue('fingerprint'),
45
- signPsbt: jest.fn().mockResolvedValue([[0, { signature: 'sig' }]]),
46
- },
47
- };
48
-
49
- const mockGetAddress = jest.fn().mockResolvedValue('change-address');
50
-
51
- const mockTrezor = {
52
- init: jest.fn(),
53
- convertToTrezorFormat: jest.fn(),
54
- signUtxoTransaction: jest.fn(),
55
- } as any;
56
-
57
- syscoinTransactions = new SyscoinTransactions(
58
- () => mockSigner,
59
- () => mockSigner, // getReadOnlySigner - same mock for testing
60
- () => mockState,
61
- mockGetAddress,
62
- mockLedger,
63
- mockTrezor
64
- );
65
- });
66
-
67
- describe('Complete Native Transaction Flow', () => {
68
- it('should handle native transaction from creation to broadcast', async () => {
69
- // Step 1: Create unsigned PSBT and get fee
70
- const { fee, psbt: unsignedPsbt } =
71
- await syscoinTransactions.getEstimateSysTransactionFee({
72
- amount: 1,
73
- receivingAddress: 'sys1qtest',
74
- feeRate: 0.00001,
75
- });
76
-
77
- expect(fee).toBeGreaterThan(0);
78
- expect(unsignedPsbt).toBeDefined();
79
-
80
- // Step 2: Sign the PSBT
81
- const signedPsbt = await syscoinTransactions.signPSBT({
82
- psbt: unsignedPsbt,
83
- isTrezor: false,
84
- isLedger: false,
85
- });
86
-
87
- // Step 3: Send the signed PSBT
88
- const result = await syscoinTransactions.sendTransaction(signedPsbt);
89
-
90
- expect(result.txid).toBe('final-txid');
91
- expect(mockSigner.main.send).toHaveBeenCalledWith(signedPsbt);
92
- });
93
- });
94
-
95
- describe('Complete Token Transaction Flow', () => {
96
- it('should handle token transaction from creation to broadcast', async () => {
97
- // Mock token lookup
98
- jest.doMock('@sidhujag/sysweb3-utils', () => ({
99
- getAsset: jest.fn().mockResolvedValue({
100
- assetGuid: 'token123',
101
- decimals: 8,
102
- }),
103
- }));
104
-
105
- // Step 1: Create unsigned token PSBT and get fee
106
- const { fee, psbt: unsignedPsbt } =
107
- await syscoinTransactions.getEstimateSysTransactionFee({
108
- amount: 100,
109
- receivingAddress: 'sys1qtest',
110
- token: { guid: 'token123', symbol: 'TEST' },
111
- });
112
-
113
- expect(fee).toBeGreaterThan(0);
114
- expect(unsignedPsbt).toBeDefined();
115
- expect(mockSigner.main.assetAllocationSend).toHaveBeenCalledWith(
116
- expect.any(Object),
117
- expect.any(Map),
118
- 'change-address',
119
- expect.any(Object),
120
- 'xpub123'
121
- );
122
-
123
- // Step 2: Sign the token PSBT
124
- const signedPsbt = await syscoinTransactions.signPSBT({
125
- psbt: unsignedPsbt,
126
- isTrezor: false,
127
- isLedger: false,
128
- });
129
-
130
- // Step 3: Send the signed PSBT
131
- const result = await syscoinTransactions.sendTransaction(signedPsbt);
132
-
133
- expect(result.txid).toBe('final-txid');
134
- });
135
- });
136
-
137
- describe('Hardware Wallet Integration', () => {
138
- it('should handle Trezor transaction flow', async () => {
139
- const mockTrezor = {
140
- init: jest.fn(),
141
- convertToTrezorFormat: jest.fn().mockReturnValue('trezor-format'),
142
- signUtxoTransaction: jest.fn().mockResolvedValue('trezor-signed-psbt'),
143
- };
144
- (syscoinTransactions as any).trezor = mockTrezor;
145
-
146
- // Create unsigned PSBT
147
- const { fee, psbt: unsignedPsbt } =
148
- await syscoinTransactions.getEstimateSysTransactionFee({
149
- amount: 1,
150
- receivingAddress: 'sys1qtest',
151
- });
152
-
153
- expect(fee).toBeGreaterThan(0);
154
- expect(unsignedPsbt).toBeDefined();
155
-
156
- // Sign with Trezor
157
- const signedPsbt = await syscoinTransactions.signPSBT({
158
- psbt: unsignedPsbt,
159
- isTrezor: true,
160
- });
161
-
162
- expect(mockTrezor.init).toHaveBeenCalled();
163
- expect(mockTrezor.signUtxoTransaction).toHaveBeenCalled();
164
- expect(signedPsbt).toBe('trezor-signed-psbt');
165
-
166
- // Send
167
- const result = await syscoinTransactions.sendTransaction(signedPsbt);
168
-
169
- expect(result.txid).toBe('final-txid');
170
- });
171
-
172
- it('should handle Ledger transaction flow', async () => {
173
- mockState.activeAccountType = KeyringAccountType.Ledger;
174
- mockState.accounts[KeyringAccountType.Ledger] = {
175
- 0: { xpub: 'ledger-xpub', id: 0, isLedgerWallet: true },
176
- };
177
-
178
- // Mock Psbt for Ledger
179
- jest.doMock('syscoinjs-lib', () => ({
180
- Psbt: {
181
- fromBase64: jest.fn().mockReturnValue({
182
- updateInput: jest.fn(),
183
- finalizeAllInputs: jest.fn(),
184
- toBase64: jest.fn().mockReturnValue('ledger-signed-psbt'),
185
- }),
186
- },
187
- }));
188
-
189
- // Create unsigned PSBT
190
- const { fee, psbt: unsignedPsbt } =
191
- await syscoinTransactions.getEstimateSysTransactionFee({
192
- amount: 1,
193
- receivingAddress: 'sys1qtest',
194
- });
195
-
196
- expect(fee).toBeGreaterThan(0);
197
- expect(unsignedPsbt).toBeDefined();
198
-
199
- // Sign with Ledger
200
- const signedPsbt = await syscoinTransactions.signPSBT({
201
- psbt: unsignedPsbt,
202
- isLedger: true,
203
- });
204
-
205
- expect(mockLedger.ledgerUtxoClient.signPsbt).toHaveBeenCalled();
206
- expect(signedPsbt).toBeDefined();
207
-
208
- // Send
209
- const result = await syscoinTransactions.sendTransaction(signedPsbt);
210
-
211
- expect(result.txid).toBe('final-txid');
212
- });
213
- });
214
-
215
- describe('Error Scenarios', () => {
216
- it('should handle signing errors separately from sending errors', async () => {
217
- // Test signing error
218
- mockSigner.hd.sign = jest
219
- .fn()
220
- .mockRejectedValue(new Error('Device disconnected'));
221
-
222
- await expect(
223
- syscoinTransactions.getEstimateSysTransactionFee({
224
- amount: 1,
225
- receivingAddress: 'sys1qtest',
226
- })
227
- ).rejects.toThrow('Failed to sign transaction: Device disconnected');
228
-
229
- // Test sending error
230
- mockSigner.main.send = jest
231
- .fn()
232
- .mockRejectedValue(new Error('Network error'));
233
-
234
- await expect(
235
- syscoinTransactions.sendTransaction('valid-psbt')
236
- ).rejects.toThrow('Failed to send transaction');
237
- });
238
-
239
- it('should require PSBT for sendTransaction', async () => {
240
- await expect(syscoinTransactions.sendTransaction('')).rejects.toThrow(
241
- 'Pre-signed PSBT is required'
242
- );
243
- });
244
- });
245
-
246
- describe('Fee Calculation', () => {
247
- it('should calculate correct fees for multi-input transactions', async () => {
248
- // Mock multiple UTXOs
249
- const mockUtxos = [
250
- { txid: 'tx1', vout: 0, value: '50000000' },
251
- { txid: 'tx2', vout: 1, value: '30000000' },
252
- { txid: 'tx3', vout: 0, value: '20000000' },
253
- ];
254
-
255
- jest.doMock('syscoinjs-lib', () => ({
256
- utils: {
257
- fetchBackendUTXOS: jest.fn().mockResolvedValue(mockUtxos),
258
- sanitizeBlockbookUTXOs: jest.fn().mockReturnValue(mockUtxos),
259
- },
260
- }));
261
-
262
- jest.doMock('coinselectsyscoin', () => ({
263
- utils: {
264
- transactionBytes: jest.fn().mockReturnValue(500), // Larger tx with multiple inputs
265
- },
266
- }));
267
-
268
- const { fee } = await syscoinTransactions.getEstimateSysTransactionFee({
269
- amount: 0.8, // Amount that requires multiple UTXOs
270
- receivingAddress: 'sys1qtest',
271
- feeRate: 0.00001,
272
- });
273
-
274
- // Fee should be proportional to transaction size
275
- expect(fee).toBeGreaterThan(0.00001); // More than minimum
276
- });
277
- });
278
-
279
- describe('RBF Support', () => {
280
- it('should create RBF-enabled transactions by default', async () => {
281
- await syscoinTransactions.getEstimateSysTransactionFee({
282
- amount: 1,
283
- receivingAddress: 'sys1qtest',
284
- });
285
-
286
- // Check that RBF was enabled in the transaction options
287
- expect(mockSigner.main.createPSBTFromRes).toHaveBeenCalled();
288
- const callArgs = mockSigner.main.createPSBTFromRes.mock.calls[0];
289
- expect(callArgs[0]).toMatchObject({ rbf: true });
290
- });
291
-
292
- it('should disable RBF when requested', async () => {
293
- await syscoinTransactions.getEstimateSysTransactionFee({
294
- amount: 1,
295
- receivingAddress: 'sys1qtest',
296
- txOptions: { rbf: false },
297
- });
298
-
299
- const callArgs = mockSigner.main.createPSBTFromRes.mock.calls[0];
300
- expect(callArgs[0]).toMatchObject({ rbf: false });
301
- });
302
- });
303
- });