agentvault 1.0.0 → 1.0.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.
Files changed (293) hide show
  1. package/.claude/settings.local.json +9 -0
  2. package/README.md +1 -1
  3. package/dist/cli/commands/approve.js +5 -5
  4. package/dist/cli/commands/archive.js +5 -5
  5. package/dist/cli/commands/backup.js +5 -5
  6. package/dist/cli/commands/cloud-backup.js +12 -12
  7. package/dist/cli/commands/decrypt.js +2 -2
  8. package/dist/cli/commands/deploy.js +1 -1
  9. package/dist/cli/commands/exec.js +2 -2
  10. package/dist/cli/commands/fetch.js +4 -4
  11. package/dist/cli/commands/inference.js +5 -5
  12. package/dist/cli/commands/init.d.ts +1 -1
  13. package/dist/cli/commands/init.js +16 -16
  14. package/dist/cli/commands/list.js +4 -4
  15. package/dist/cli/commands/package.js +2 -2
  16. package/dist/cli/commands/profile.js +1 -1
  17. package/dist/cli/commands/rebuild.js +2 -2
  18. package/dist/cli/commands/show.js +1 -1
  19. package/dist/cli/commands/status.d.ts +1 -1
  20. package/dist/cli/commands/status.js +8 -8
  21. package/dist/cli/commands/trace.js +1 -1
  22. package/dist/cli/commands/wallet-export.js +1 -1
  23. package/dist/cli/commands/wallet-sign.js +1 -1
  24. package/dist/cli/commands/wallet.d.ts +1 -1
  25. package/dist/cli/commands/wallet.js +1 -1
  26. package/dist/cli/index.d.ts +2 -2
  27. package/dist/cli/index.js +3 -3
  28. package/dist/src/archival/archive-manager.d.ts +85 -0
  29. package/dist/src/archival/archive-manager.js +294 -0
  30. package/dist/src/archival/arweave-client.d.ts +88 -0
  31. package/dist/src/archival/arweave-client.js +223 -0
  32. package/dist/src/archival/index.d.ts +8 -0
  33. package/{src/archival/index.ts → dist/src/archival/index.js} +1 -1
  34. package/dist/src/backup/backup.d.ts +67 -0
  35. package/dist/src/backup/backup.js +231 -0
  36. package/dist/src/backup/index.d.ts +7 -0
  37. package/{src/backup/index.ts → dist/src/backup/index.js} +1 -1
  38. package/dist/src/cloud-storage/cloud-sync.d.ts +49 -0
  39. package/dist/src/cloud-storage/cloud-sync.js +372 -0
  40. package/dist/src/cloud-storage/index.d.ts +11 -0
  41. package/{src/cloud-storage/index.ts → dist/src/cloud-storage/index.js} +1 -1
  42. package/dist/src/cloud-storage/provider-detector.d.ts +34 -0
  43. package/dist/src/cloud-storage/provider-detector.js +158 -0
  44. package/{src/cloud-storage/types.ts → dist/src/cloud-storage/types.d.ts} +40 -53
  45. package/dist/src/cloud-storage/types.js +10 -0
  46. package/dist/src/debugging/index.d.ts +6 -0
  47. package/{src/debugging/index.ts → dist/src/debugging/index.js} +1 -1
  48. package/dist/src/debugging/logs.d.ts +32 -0
  49. package/dist/src/debugging/logs.js +158 -0
  50. package/dist/src/debugging/types.d.ts +91 -0
  51. package/dist/src/debugging/types.js +5 -0
  52. package/dist/src/deployment/deployer.d.ts +52 -0
  53. package/dist/src/deployment/deployer.js +211 -0
  54. package/dist/src/deployment/icpClient.d.ts +144 -0
  55. package/dist/src/deployment/icpClient.js +545 -0
  56. package/dist/src/deployment/index.d.ts +11 -0
  57. package/dist/src/deployment/index.js +14 -0
  58. package/dist/src/deployment/promotion.d.ts +32 -0
  59. package/dist/src/deployment/promotion.js +114 -0
  60. package/dist/src/deployment/types.d.ts +101 -0
  61. package/dist/src/deployment/types.js +5 -0
  62. package/dist/src/icp/batch.d.ts +112 -0
  63. package/dist/src/icp/batch.js +273 -0
  64. package/dist/src/icp/cycles.d.ts +29 -0
  65. package/{src/icp/cycles.ts → dist/src/icp/cycles.js} +8 -22
  66. package/dist/src/icp/environment.d.ts +60 -0
  67. package/dist/src/icp/environment.js +183 -0
  68. package/dist/src/icp/icpcli.d.ts +204 -0
  69. package/dist/src/icp/icpcli.js +374 -0
  70. package/dist/src/icp/icwasm.d.ts +94 -0
  71. package/dist/src/icp/icwasm.js +197 -0
  72. package/dist/src/icp/identity.d.ts +50 -0
  73. package/{src/icp/identity.ts → dist/src/icp/identity.js} +15 -28
  74. package/dist/src/icp/index.d.ts +16 -0
  75. package/dist/src/icp/index.js +20 -0
  76. package/dist/src/icp/optimization.d.ts +16 -0
  77. package/dist/src/icp/optimization.js +225 -0
  78. package/dist/src/icp/tokens.d.ts +24 -0
  79. package/{src/icp/tokens.ts → dist/src/icp/tokens.js} +5 -12
  80. package/dist/src/icp/tool-detector.d.ts +31 -0
  81. package/dist/src/icp/tool-detector.js +104 -0
  82. package/dist/src/icp/types.d.ts +493 -0
  83. package/dist/src/icp/types.js +7 -0
  84. package/dist/src/index.d.ts +12 -0
  85. package/dist/src/index.js +18 -0
  86. package/dist/src/inference/bittensor-client.d.ts +108 -0
  87. package/dist/src/inference/bittensor-client.js +224 -0
  88. package/dist/src/inference/index.d.ts +8 -0
  89. package/{src/inference/index.ts → dist/src/inference/index.js} +1 -1
  90. package/dist/src/inference/inference-manager.d.ts +76 -0
  91. package/dist/src/inference/inference-manager.js +228 -0
  92. package/dist/src/metrics/index.d.ts +7 -0
  93. package/{src/metrics/index.ts → dist/src/metrics/index.js} +1 -1
  94. package/dist/src/metrics/metrics.d.ts +39 -0
  95. package/dist/src/metrics/metrics.js +129 -0
  96. package/dist/src/monitoring/alerting.d.ts +51 -0
  97. package/dist/src/monitoring/alerting.js +169 -0
  98. package/dist/src/monitoring/health.d.ts +40 -0
  99. package/dist/src/monitoring/health.js +164 -0
  100. package/dist/src/monitoring/index.d.ts +10 -0
  101. package/dist/src/monitoring/index.js +12 -0
  102. package/dist/src/monitoring/info.d.ts +15 -0
  103. package/dist/src/monitoring/info.js +109 -0
  104. package/dist/src/monitoring/types.d.ts +93 -0
  105. package/dist/src/monitoring/types.js +7 -0
  106. package/dist/src/network/index.d.ts +5 -0
  107. package/{src/network/index.ts → dist/src/network/index.js} +1 -1
  108. package/dist/src/network/network-config.d.ts +31 -0
  109. package/dist/src/network/network-config.js +109 -0
  110. package/dist/src/packaging/compiler.d.ts +61 -0
  111. package/dist/src/packaging/compiler.js +562 -0
  112. package/dist/src/packaging/config-persistence.d.ts +46 -0
  113. package/dist/src/packaging/config-persistence.js +108 -0
  114. package/dist/src/packaging/config-schemas.d.ts +115 -0
  115. package/dist/src/packaging/config-schemas.js +43 -0
  116. package/dist/src/packaging/detector.d.ts +26 -0
  117. package/dist/src/packaging/detector.js +193 -0
  118. package/dist/src/packaging/index.d.ts +16 -0
  119. package/dist/src/packaging/index.js +22 -0
  120. package/dist/src/packaging/packager.d.ts +31 -0
  121. package/dist/src/packaging/packager.js +90 -0
  122. package/dist/src/packaging/parsers/clawdbot.d.ts +19 -0
  123. package/dist/src/packaging/parsers/clawdbot.js +231 -0
  124. package/dist/src/packaging/parsers/cline.d.ts +26 -0
  125. package/dist/src/packaging/parsers/cline.js +185 -0
  126. package/dist/src/packaging/parsers/generic.d.ts +27 -0
  127. package/dist/src/packaging/parsers/generic.js +228 -0
  128. package/dist/src/packaging/parsers/goose.d.ts +26 -0
  129. package/dist/src/packaging/parsers/goose.js +175 -0
  130. package/dist/src/packaging/parsers/index.d.ts +11 -0
  131. package/{src/packaging/parsers/index.ts → dist/src/packaging/parsers/index.js} +1 -1
  132. package/dist/src/packaging/serializer.d.ts +108 -0
  133. package/dist/src/packaging/serializer.js +153 -0
  134. package/dist/src/packaging/types.d.ts +131 -0
  135. package/dist/src/packaging/types.js +5 -0
  136. package/dist/src/packaging/wasmedge-compiler.d.ts +76 -0
  137. package/dist/src/packaging/wasmedge-compiler.js +349 -0
  138. package/dist/src/security/index.d.ts +11 -0
  139. package/{src/security/index.ts → dist/src/security/index.js} +1 -4
  140. package/dist/src/security/multisig.d.ts +102 -0
  141. package/dist/src/security/multisig.js +283 -0
  142. package/dist/src/security/types.d.ts +207 -0
  143. package/dist/src/security/types.js +217 -0
  144. package/dist/src/security/vetkeys.d.ts +179 -0
  145. package/dist/src/security/vetkeys.js +499 -0
  146. package/dist/src/testing/index.d.ts +6 -0
  147. package/{src/testing/index.ts → dist/src/testing/index.js} +1 -1
  148. package/dist/src/testing/local-runner.d.ts +23 -0
  149. package/dist/src/testing/local-runner.js +226 -0
  150. package/dist/src/testing/types.d.ts +98 -0
  151. package/dist/src/testing/types.js +5 -0
  152. package/dist/src/wallet/cbor-serializer.d.ts +82 -0
  153. package/dist/src/wallet/cbor-serializer.js +282 -0
  154. package/dist/src/wallet/chain-dispatcher.d.ts +112 -0
  155. package/dist/src/wallet/chain-dispatcher.js +241 -0
  156. package/dist/src/wallet/cross-chain-aggregator.d.ts +119 -0
  157. package/dist/src/wallet/cross-chain-aggregator.js +235 -0
  158. package/dist/src/wallet/index.d.ts +16 -0
  159. package/dist/src/wallet/index.js +22 -0
  160. package/dist/src/wallet/key-derivation.d.ts +117 -0
  161. package/dist/src/wallet/key-derivation.js +325 -0
  162. package/dist/src/wallet/providers/base-provider.d.ts +111 -0
  163. package/dist/src/wallet/providers/base-provider.js +58 -0
  164. package/dist/src/wallet/providers/cketh-provider.d.ts +104 -0
  165. package/dist/src/wallet/providers/cketh-provider.js +343 -0
  166. package/dist/src/wallet/providers/polkadot-provider.d.ts +115 -0
  167. package/dist/src/wallet/providers/polkadot-provider.js +407 -0
  168. package/dist/src/wallet/providers/solana-provider.d.ts +102 -0
  169. package/dist/src/wallet/providers/solana-provider.js +393 -0
  170. package/dist/src/wallet/transaction-queue.d.ts +133 -0
  171. package/dist/src/wallet/transaction-queue.js +195 -0
  172. package/dist/src/wallet/types.d.ts +167 -0
  173. package/dist/src/wallet/types.js +5 -0
  174. package/dist/src/wallet/vetkeys-adapter.d.ts +134 -0
  175. package/dist/src/wallet/vetkeys-adapter.js +313 -0
  176. package/dist/src/wallet/wallet-manager.d.ts +202 -0
  177. package/dist/src/wallet/wallet-manager.js +451 -0
  178. package/dist/src/wallet/wallet-storage.d.ts +131 -0
  179. package/dist/src/wallet/wallet-storage.js +274 -0
  180. package/macos-wallet-app/AgentVaultWallet/App/AgentVaultWalletApp.swift +54 -0
  181. package/macos-wallet-app/AgentVaultWallet/Models/AppState.swift +102 -0
  182. package/macos-wallet-app/AgentVaultWallet/Models/Chain.swift +121 -0
  183. package/macos-wallet-app/AgentVaultWallet/Models/Wallet.swift +98 -0
  184. package/macos-wallet-app/AgentVaultWallet/Resources/AgentVaultWallet.entitlements +27 -0
  185. package/macos-wallet-app/AgentVaultWallet/Resources/Info.plist +69 -0
  186. package/macos-wallet-app/AgentVaultWallet/Services/BackupService.swift +270 -0
  187. package/macos-wallet-app/AgentVaultWallet/Services/CLIBridge.swift +367 -0
  188. package/macos-wallet-app/AgentVaultWallet/Services/CryptoService.swift +157 -0
  189. package/macos-wallet-app/AgentVaultWallet/Services/FileService.swift +120 -0
  190. package/macos-wallet-app/AgentVaultWallet/Services/KeychainService.swift +219 -0
  191. package/macos-wallet-app/AgentVaultWallet/Utilities/Constants.swift +44 -0
  192. package/macos-wallet-app/AgentVaultWallet/Utilities/Extensions.swift +115 -0
  193. package/macos-wallet-app/AgentVaultWallet/ViewModels/BackupViewModel.swift +237 -0
  194. package/macos-wallet-app/AgentVaultWallet/ViewModels/CreateWalletViewModel.swift +137 -0
  195. package/macos-wallet-app/AgentVaultWallet/ViewModels/ImportWalletViewModel.swift +179 -0
  196. package/macos-wallet-app/AgentVaultWallet/ViewModels/WalletStore.swift +286 -0
  197. package/macos-wallet-app/AgentVaultWallet/Views/Backup/BackupView.swift +235 -0
  198. package/macos-wallet-app/AgentVaultWallet/Views/Backup/RestoreView.swift +316 -0
  199. package/macos-wallet-app/AgentVaultWallet/Views/Create/CreateWalletFlow.swift +438 -0
  200. package/macos-wallet-app/AgentVaultWallet/Views/Import/ImportWalletFlow.swift +399 -0
  201. package/macos-wallet-app/AgentVaultWallet/Views/MainView.swift +134 -0
  202. package/macos-wallet-app/AgentVaultWallet/Views/Settings/SettingsView.swift +276 -0
  203. package/macos-wallet-app/AgentVaultWallet/Views/Sidebar/SidebarView.swift +133 -0
  204. package/macos-wallet-app/AgentVaultWallet/Views/Wallet/DashboardView.swift +233 -0
  205. package/macos-wallet-app/AgentVaultWallet/Views/Wallet/WalletDetailView.swift +281 -0
  206. package/macos-wallet-app/AgentVaultWallet/Views/Wallet/WalletListView.swift +280 -0
  207. package/macos-wallet-app/AgentVaultWallet/Views/Welcome/WelcomeView.swift +176 -0
  208. package/macos-wallet-app/Makefile +47 -0
  209. package/macos-wallet-app/project.yml +40 -0
  210. package/macos-wallet-app/setup.sh +73 -0
  211. package/package.json +10 -2
  212. package/backups/agentvault-backup-test-agent-2026-02-12T17-54-28-967Z.json +0 -28
  213. package/backups/agentvault-backup-test-agent-2026-02-12T17-54-29-032Z.backup +0 -1
  214. package/backups/agentvault-backup-test-agent-2026-02-12T17-57-42-373Z.json +0 -28
  215. package/backups/agentvault-backup-test-agent-2026-02-12T17-57-42-428Z.backup +0 -1
  216. package/backups/agentvault-backup-test-agent-2026-02-12T18-52-25-132Z.json +0 -28
  217. package/backups/agentvault-backup-test-agent-2026-02-12T18-52-25-247Z.backup +0 -1
  218. package/backups/agentvault-backup-test-agent-2026-02-12T18-54-09-216Z.json +0 -28
  219. package/backups/agentvault-backup-test-agent-2026-02-12T18-54-09-283Z.backup +0 -1
  220. package/backups/agentvault-backup-test-agent-2026-02-12T22-18-22-772Z.backup +0 -1
  221. package/backups/agentvault-backup-test-agent-2026-02-12T22-18-22-793Z.json +0 -28
  222. package/backups/test-backup.json +0 -28
  223. package/scripts/dev-dashboard.mjs +0 -84
  224. package/site/README.md +0 -63
  225. package/site/docusaurus.config.ts +0 -148
  226. package/site/package-lock.json +0 -18383
  227. package/site/package.json +0 -47
  228. package/site/sidebars.ts +0 -86
  229. package/site/static/.gitkeep +0 -0
  230. package/site/static/img/logo.svg +0 -28
  231. package/site/static/img/og-image.svg +0 -35
  232. package/src/archival/archive-manager.ts +0 -372
  233. package/src/archival/arweave-client.ts +0 -289
  234. package/src/backup/backup.ts +0 -315
  235. package/src/cloud-storage/cloud-sync.ts +0 -461
  236. package/src/cloud-storage/provider-detector.ts +0 -198
  237. package/src/debugging/logs.ts +0 -193
  238. package/src/debugging/types.ts +0 -100
  239. package/src/deployment/deployer.ts +0 -274
  240. package/src/deployment/icpClient.ts +0 -620
  241. package/src/deployment/index.ts +0 -46
  242. package/src/deployment/promotion.ts +0 -161
  243. package/src/deployment/types.ts +0 -111
  244. package/src/icp/batch.ts +0 -374
  245. package/src/icp/environment.ts +0 -215
  246. package/src/icp/icpcli.ts +0 -438
  247. package/src/icp/icwasm.ts +0 -222
  248. package/src/icp/index.ts +0 -94
  249. package/src/icp/optimization.ts +0 -242
  250. package/src/icp/tool-detector.ts +0 -110
  251. package/src/icp/types.ts +0 -574
  252. package/src/index.ts +0 -25
  253. package/src/inference/bittensor-client.ts +0 -304
  254. package/src/inference/inference-manager.ts +0 -327
  255. package/src/metrics/metrics.ts +0 -186
  256. package/src/monitoring/alerting.ts +0 -190
  257. package/src/monitoring/health.ts +0 -197
  258. package/src/monitoring/index.ts +0 -38
  259. package/src/monitoring/info.ts +0 -114
  260. package/src/monitoring/types.ts +0 -99
  261. package/src/network/network-config.ts +0 -129
  262. package/src/packaging/compiler.ts +0 -647
  263. package/src/packaging/config-persistence.ts +0 -135
  264. package/src/packaging/config-schemas.ts +0 -156
  265. package/src/packaging/detector.ts +0 -220
  266. package/src/packaging/index.ts +0 -90
  267. package/src/packaging/packager.ts +0 -118
  268. package/src/packaging/parsers/clawdbot.ts +0 -278
  269. package/src/packaging/parsers/cline.ts +0 -223
  270. package/src/packaging/parsers/generic.ts +0 -266
  271. package/src/packaging/parsers/goose.ts +0 -214
  272. package/src/packaging/serializer.ts +0 -260
  273. package/src/packaging/types.ts +0 -144
  274. package/src/packaging/wasmedge-compiler.ts +0 -406
  275. package/src/security/multisig.ts +0 -415
  276. package/src/security/types.ts +0 -416
  277. package/src/security/vetkeys.ts +0 -655
  278. package/src/testing/local-runner.ts +0 -264
  279. package/src/testing/types.ts +0 -104
  280. package/src/wallet/cbor-serializer.ts +0 -323
  281. package/src/wallet/chain-dispatcher.ts +0 -313
  282. package/src/wallet/cross-chain-aggregator.ts +0 -346
  283. package/src/wallet/index.ts +0 -76
  284. package/src/wallet/key-derivation.ts +0 -425
  285. package/src/wallet/providers/base-provider.ts +0 -154
  286. package/src/wallet/providers/cketh-provider.ts +0 -434
  287. package/src/wallet/providers/polkadot-provider.ts +0 -503
  288. package/src/wallet/providers/solana-provider.ts +0 -490
  289. package/src/wallet/transaction-queue.ts +0 -284
  290. package/src/wallet/types.ts +0 -178
  291. package/src/wallet/vetkeys-adapter.ts +0 -431
  292. package/src/wallet/wallet-manager.ts +0 -597
  293. package/src/wallet/wallet-storage.ts +0 -380
@@ -1,503 +0,0 @@
1
- /**
2
- * Polkadot Wallet Provider (Full Implementation)
3
- *
4
- * Complete provider for Polkadot wallet operations.
5
- * Integrates with @polkadot/util-crypto for key derivation.
6
- * Uses @polkadot/api for real RPC network interactions.
7
- */
8
-
9
- import type {
10
- Balance,
11
- Transaction,
12
- TransactionRequest,
13
- SignedTransaction,
14
- ProviderConfig,
15
- } from '../types.js';
16
- import { BaseWalletProvider } from './base-provider.js';
17
- import {
18
- sr25519PairFromSeed,
19
- sr25519Sign,
20
- checkAddress,
21
- cryptoWaitReady,
22
- } from '@polkadot/util-crypto';
23
- import {
24
- u8aToHex,
25
- hexToU8a,
26
- } from '@polkadot/util';
27
- import { ApiPromise, WsProvider } from '@polkadot/api';
28
- import type { KeyringPair } from '@polkadot/keyring/types';
29
- import { Keyring } from '@polkadot/keyring';
30
-
31
- /**
32
- * Polkadot provider configuration
33
- */
34
- interface PolkadotConfig extends ProviderConfig {
35
- /** Polkadot JSON-RPC endpoint (WS or HTTP) */
36
- rpcUrl: string;
37
- /** Chain type (mainnet, testnet, dev) */
38
- network?: 'mainnet' | 'testnet' | 'dev';
39
- /** Chain type (polkadot, kusama, westend, astar) */
40
- chainType?: 'polkadot' | 'kusama' | 'westend' | 'astar';
41
- /** SS58 prefix for address encoding */
42
- ss58Format?: number;
43
- }
44
-
45
- /**
46
- * Polkadot wallet provider
47
- */
48
- export class PolkadotProvider extends BaseWalletProvider {
49
- private keyringPair: KeyringPair | null = null;
50
- private api: ApiPromise | null = null;
51
- private ss58Format: number;
52
- private chainType: string;
53
-
54
- constructor(config: PolkadotConfig) {
55
- super(config);
56
- this.ss58Format = config.ss58Format || 0;
57
- this.chainType = config.chainType || 'polkadot';
58
- }
59
-
60
- private getApi() {
61
- if (!this.api) {
62
- throw new Error('API not connected');
63
- }
64
- return this.api;
65
- }
66
-
67
- private getSystemQuery() {
68
- return this.getApi().query.system as any;
69
- }
70
-
71
- private getBalancesTx() {
72
- return this.getApi().tx.balances as any;
73
- }
74
-
75
- private getRpcChain() {
76
- return this.getApi().rpc.chain as any;
77
- }
78
-
79
- /**
80
- * Connect to Polkadot network via RPC
81
- */
82
- async connect(): Promise<void> {
83
- try {
84
- await cryptoWaitReady();
85
-
86
- const rpcUrl = this.config.rpcUrl || this.getDefaultRpcUrl();
87
- const provider = new WsProvider(rpcUrl);
88
-
89
- this.api = await ApiPromise.create({ provider });
90
-
91
- await this.api.isReady;
92
-
93
- this.connected = true;
94
- console.log(`Connected to ${this.chainType} network via ${rpcUrl}`);
95
- } catch (error) {
96
- const message = error instanceof Error ? error.message : 'Unknown error';
97
- throw new Error(`Failed to connect to Polkadot network: ${message}`);
98
- }
99
- }
100
-
101
- /**
102
- * Disconnect from Polkadot network
103
- */
104
- async disconnect(): Promise<void> {
105
- if (this.api) {
106
- await this.api.disconnect();
107
- this.api = null;
108
- }
109
- this.keyringPair = null;
110
- this.connected = false;
111
- }
112
-
113
- /**
114
- * Get wallet balance
115
- */
116
- async getBalance(address: string): Promise<Balance> {
117
- if (!this.connected || !this.api) {
118
- throw new Error('Provider not connected');
119
- }
120
-
121
- try {
122
- const accountInfo = await this.getSystemQuery().account(address);
123
- const data = accountInfo.toJSON() as any;
124
- const freeBalance = ((data?.data?.free as string) ?? '0');
125
- const reserved = ((data?.data?.reserved as string) ?? '0');
126
- const totalBalance = (BigInt(freeBalance) + BigInt(reserved)).toString();
127
-
128
- const balanceInDot = parseFloat(totalBalance) / 10_000_000_000;
129
-
130
- const blockNumber = await this.getSystemQuery().number();
131
-
132
- return {
133
- amount: balanceInDot.toString(),
134
- denomination: 'DOT',
135
- chain: this.chainType as any,
136
- address,
137
- blockNumber: Number(blockNumber),
138
- };
139
- } catch (error) {
140
- const message = error instanceof Error ? error.message : 'Unknown error';
141
- throw new Error(`Failed to get balance: ${message}`);
142
- }
143
- }
144
-
145
- /**
146
- * Send transaction
147
- */
148
- async sendTransaction(
149
- from: string,
150
- request: TransactionRequest
151
- ): Promise<Transaction> {
152
- if (!this.connected || !this.api || !this.keyringPair) {
153
- throw new Error('Provider not connected or no wallet loaded');
154
- }
155
-
156
- try {
157
- const transferAmount = this.parseDotAmount(request.amount);
158
-
159
- const tx = this.getBalancesTx().transfer(request.to, transferAmount);
160
-
161
- const hash = await tx.signAndSend(this.keyringPair);
162
-
163
- const fee = await this.estimateFee(request);
164
-
165
- return {
166
- hash: hash.toString(),
167
- from,
168
- to: request.to,
169
- amount: request.amount,
170
- chain: this.chainType as any,
171
- timestamp: Date.now(),
172
- status: 'pending',
173
- fee,
174
- data: { memo: request.memo },
175
- };
176
- } catch (error) {
177
- const message = error instanceof Error ? error.message : 'Unknown error';
178
- throw new Error(`Failed to send transaction: ${message}`);
179
- }
180
- }
181
-
182
- /**
183
- * Sign transaction
184
- */
185
- async signTransaction(
186
- tx: any,
187
- privateKey: string
188
- ): Promise<SignedTransaction> {
189
- if (!this.api) {
190
- throw new Error('Provider not connected');
191
- }
192
-
193
- try {
194
- const keypair = this.createKeyringPair(privateKey);
195
- const transferAmount = this.parseDotAmount(tx.amount);
196
-
197
- const unsignedTx = this.getBalancesTx().transfer(tx.to, transferAmount);
198
- const signedTx = await unsignedTx.signAsync(keypair);
199
-
200
- return {
201
- txHash: signedTx.hash.toString(),
202
- signedTx: signedTx.toHex(),
203
- signature: u8aToHex(signedTx.signature),
204
- request: tx,
205
- };
206
- } catch (error) {
207
- const message = error instanceof Error ? error.message : 'Unknown error';
208
- throw new Error(`Failed to sign transaction: ${message}`);
209
- }
210
- }
211
-
212
- /**
213
- * Get transaction history
214
- */
215
- async getTransactionHistory(address: string): Promise<Transaction[]> {
216
- if (!this.connected || !this.api) {
217
- throw new Error('Provider not connected');
218
- }
219
-
220
- try {
221
- const transactions: Transaction[] = [];
222
-
223
- const blockNumber = await this.getSystemQuery().number();
224
- const latestBlocks = Math.min(Number(blockNumber), 100);
225
-
226
- for (let i = 0; i < latestBlocks; i++) {
227
- const blockHash = await this.getRpcChain().getBlockHash(Number(blockNumber) - i);
228
-
229
- const events = await this.getSystemQuery().events.at(blockHash);
230
- const eventRecords = events.toHuman() as any[];
231
-
232
- for (const event of eventRecords) {
233
- if (event.event?.section === 'balances' && event.event?.method === 'Transfer') {
234
- const eventData = event.event.data;
235
- const [from, to, amount] = eventData;
236
-
237
- if (from.toString() === address || to.toString() === address) {
238
- transactions.push({
239
- hash: blockHash.toString(),
240
- from: from.toString(),
241
- to: to.toString(),
242
- amount: this.formatPlancks(amount.toString()),
243
- chain: this.chainType as any,
244
- timestamp: Date.now() - (i * 6000),
245
- status: 'confirmed',
246
- fee: '0',
247
- });
248
- }
249
- }
250
- }
251
- }
252
-
253
- return transactions.slice(0, 20);
254
- } catch (error) {
255
- const message = error instanceof Error ? error.message : 'Unknown error';
256
- console.warn(`Failed to get transaction history: ${message}`);
257
- return [];
258
- }
259
- }
260
-
261
- /**
262
- * Validate Polkadot address (SS58 format)
263
- */
264
- validateAddress(address: string): boolean {
265
- try {
266
- const [isValid] = checkAddress(address, this.ss58Format);
267
- return isValid;
268
- } catch {
269
- return false;
270
- }
271
- }
272
-
273
- /**
274
- * Estimate transaction fee
275
- */
276
- async estimateFee(request: TransactionRequest): Promise<string> {
277
- if (!this.connected || !this.api || !this.keyringPair) {
278
- return '0.01';
279
- }
280
-
281
- try {
282
- const transferAmount = this.parseDotAmount(request.amount);
283
-
284
- const tx = this.getBalancesTx().transfer(request.to, transferAmount);
285
-
286
- const info = await tx.paymentInfo(this.keyringPair);
287
-
288
- const partialFee = info.partialFee.toString();
289
- const feeInDot = parseFloat(partialFee) / 10_000_000_000;
290
-
291
- return feeInDot.toFixed(6);
292
- } catch (_error) {
293
- return '0.01';
294
- }
295
- }
296
-
297
- /**
298
- * Get current block number
299
- */
300
- async getBlockNumber(): Promise<number> {
301
- if (!this.connected || !this.api) {
302
- throw new Error('Provider not connected');
303
- }
304
-
305
- try {
306
- const blockNumber = await this.getSystemQuery().number();
307
- return Number(blockNumber);
308
- } catch (error) {
309
- const message = error instanceof Error ? error.message : 'Unknown error';
310
- throw new Error(`Failed to get block number: ${message}`);
311
- }
312
- }
313
-
314
- /**
315
- * Get transaction by hash
316
- */
317
- async getTransaction(txHash: string): Promise<Transaction | null> {
318
- if (!this.connected || !this.api) {
319
- throw new Error('Provider not connected');
320
- }
321
-
322
- try {
323
- const blockHash = await this.getRpcChain().getBlockHash();
324
- const events = await this.getSystemQuery().events.at(blockHash || undefined);
325
- const eventRecords = events.toHuman() as any[];
326
-
327
- let from = '';
328
- let to = '';
329
- let amount = '0';
330
- let found = false;
331
-
332
- for (const event of eventRecords) {
333
- if (event.event?.section === 'balances' && event.event?.method === 'Transfer' && event.event?.data) {
334
- const eventData = event.event?.data as [string, string, string];
335
- [from, to, amount] = eventData;
336
- found = true;
337
- }
338
- if (event.event?.section === 'system' && event.event?.method === 'ExtrinsicSuccess') {
339
- break;
340
- }
341
- }
342
-
343
- if (found && (from || to)) {
344
- return {
345
- hash: txHash,
346
- from: from.toString(),
347
- to: to.toString(),
348
- amount: this.formatPlancks(amount.toString()),
349
- chain: this.chainType as any,
350
- timestamp: Date.now(),
351
- status: 'confirmed',
352
- fee: '0',
353
- };
354
- }
355
-
356
- return null;
357
- } catch (error) {
358
- const message = error instanceof Error ? error.message : 'Unknown error';
359
- throw new Error(`Failed to get transaction: ${message}`);
360
- }
361
- }
362
-
363
- /**
364
- * Initialize keypair from wallet data
365
- */
366
- async initKeypair(mnemonic: string, derivationPath?: string): Promise<void> {
367
- try {
368
- await cryptoWaitReady();
369
-
370
- const keyring = new Keyring({ type: 'sr25519', ss58Format: this.ss58Format });
371
-
372
- const path = derivationPath || '//hard//stash';
373
-
374
- this.keyringPair = keyring.addFromMnemonic(mnemonic, undefined, 'sr25519');
375
-
376
- if (derivationPath && derivationPath !== '//hard//stash') {
377
- const derived = keyring.addFromUri(path, undefined, 'sr25519');
378
- this.keyringPair = derived;
379
- }
380
-
381
- console.log('Polkadot keypair initialized for derivation:', path);
382
- console.log('Address:', this.getAddress());
383
- } catch (error) {
384
- const message = error instanceof Error ? error.message : 'Unknown error';
385
- throw new Error(`Failed to initialize Polkadot keypair: ${message}`);
386
- }
387
- }
388
-
389
- /**
390
- * Initialize from private key
391
- */
392
- async initFromPrivateKey(privateKey: string): Promise<void> {
393
- try {
394
- this.keyringPair = this.createKeyringPair(privateKey);
395
-
396
- console.log('Polkadot keypair initialized from private key');
397
- console.log('Address:', this.getAddress());
398
- } catch (error) {
399
- const message = error instanceof Error ? error.message : 'Unknown error';
400
- throw new Error(`Failed to initialize Polkadot keypair from private key: ${message}`);
401
- }
402
- }
403
-
404
- /**
405
- * Create KeyringPair from private key
406
- */
407
- private createKeyringPair(privateKeyHex: string): KeyringPair {
408
- const keyring = new Keyring({ type: 'sr25519', ss58Format: this.ss58Format });
409
- const privateKeyBytes = hexToU8a(privateKeyHex);
410
- const pair = keyring.addFromSeed(privateKeyBytes);
411
- return pair;
412
- }
413
-
414
- /**
415
- * Get address from keypair
416
- */
417
- getAddress(): string | null {
418
- if (!this.keyringPair) {
419
- return null;
420
- }
421
-
422
- return this.keyringPair.address;
423
- }
424
-
425
- /**
426
- * Get public key
427
- */
428
- getPublicKey(): string | null {
429
- if (!this.keyringPair) {
430
- return null;
431
- }
432
-
433
- return u8aToHex(this.keyringPair.publicKey);
434
- }
435
-
436
- /**
437
- * Parse DOT amount (convert from string to Plancks)
438
- */
439
- private parseDotAmount(amountStr: string): bigint {
440
- try {
441
- const cleanAmount = amountStr.replace(/,/g, '').trim();
442
- const amount = parseFloat(cleanAmount);
443
- const plancks = Math.floor(amount * 10_000_000_000);
444
- return BigInt(plancks);
445
- } catch (_error) {
446
- return BigInt(0);
447
- }
448
- }
449
-
450
- /**
451
- * Format Plancks to DOT
452
- */
453
- private formatPlancks(plancks: string): string {
454
- try {
455
- const amount = parseFloat(plancks) / 10_000_000_000;
456
- return amount.toFixed(6);
457
- } catch (_error) {
458
- return '0';
459
- }
460
- }
461
-
462
- /**
463
- * Create SR25519 signature for transaction
464
- */
465
- async createSignature(
466
- payload: Uint8Array,
467
- privateKeyHex: string
468
- ): Promise<Uint8Array> {
469
- try {
470
- const privateKeyBytes = hexToU8a(privateKeyHex);
471
- const keypair = sr25519PairFromSeed(privateKeyBytes);
472
-
473
- const signature = sr25519Sign(payload, { publicKey: keypair.publicKey, secretKey: keypair.secretKey });
474
-
475
- return signature;
476
- } catch (error) {
477
- const msg = error instanceof Error ? error.message : 'Unknown error';
478
- throw new Error(`Failed to create Polkadot signature: ${msg}`);
479
- }
480
- }
481
-
482
- /**
483
- * Get default RPC URL for chain type
484
- * Checks environment variables first, then falls back to public RPC endpoints
485
- */
486
- private getDefaultRpcUrl(): string {
487
- const envUrls: Record<string, string | undefined> = {
488
- polkadot: process.env.POLKADOT_RPC_URL,
489
- kusama: process.env.KUSAMA_RPC_URL,
490
- westend: process.env.WESTEND_RPC_URL,
491
- astar: process.env.ASTAR_RPC_URL,
492
- };
493
-
494
- const publicUrls: Record<string, string> = {
495
- polkadot: 'wss://rpc.polkadot.io',
496
- kusama: 'wss://kusama-rpc.polkadot.io',
497
- westend: 'wss://westend-rpc.polkadot.io',
498
- astar: 'wss://rpc.astar.network',
499
- };
500
-
501
- return envUrls[this.chainType] || publicUrls[this.chainType] || publicUrls.polkadot!;
502
- }
503
- }