@veridex/sdk 1.0.0-beta.8 → 1.0.1

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 (130) hide show
  1. package/LICENSE +170 -21
  2. package/README.md +574 -117
  3. package/dist/EVMClient-DtqvdfUP.d.mts +376 -0
  4. package/dist/auth/prepareAuth.d.mts +25 -0
  5. package/dist/auth/prepareAuth.js +2406 -0
  6. package/dist/auth/prepareAuth.js.map +1 -0
  7. package/dist/auth/prepareAuth.mjs +151 -0
  8. package/dist/auth/prepareAuth.mjs.map +1 -0
  9. package/dist/chains/aptos/index.d.mts +6 -5
  10. package/dist/chains/aptos/index.js +66 -39
  11. package/dist/chains/aptos/index.js.map +1 -1
  12. package/dist/chains/aptos/index.mjs +5 -547
  13. package/dist/chains/aptos/index.mjs.map +1 -1
  14. package/dist/chains/avalanche/index.d.mts +137 -0
  15. package/dist/chains/avalanche/index.js +1555 -0
  16. package/dist/chains/avalanche/index.js.map +1 -0
  17. package/dist/chains/avalanche/index.mjs +10 -0
  18. package/dist/chains/avalanche/index.mjs.map +1 -0
  19. package/dist/chains/evm/index.d.mts +5 -3
  20. package/dist/chains/evm/index.js +165 -3
  21. package/dist/chains/evm/index.js.map +1 -1
  22. package/dist/chains/evm/index.mjs +8 -1200
  23. package/dist/chains/evm/index.mjs.map +1 -1
  24. package/dist/chains/solana/index.d.mts +1 -1
  25. package/dist/chains/solana/index.js.map +1 -1
  26. package/dist/chains/solana/index.mjs +4 -486
  27. package/dist/chains/solana/index.mjs.map +1 -1
  28. package/dist/chains/stacks/index.d.mts +559 -0
  29. package/dist/chains/stacks/index.js +1207 -0
  30. package/dist/chains/stacks/index.js.map +1 -0
  31. package/dist/chains/stacks/index.mjs +71 -0
  32. package/dist/chains/stacks/index.mjs.map +1 -0
  33. package/dist/chains/starknet/index.d.mts +3 -3
  34. package/dist/chains/starknet/index.js.map +1 -1
  35. package/dist/chains/starknet/index.mjs +5 -503
  36. package/dist/chains/starknet/index.mjs.map +1 -1
  37. package/dist/chains/sui/index.d.mts +2 -2
  38. package/dist/chains/sui/index.js.map +1 -1
  39. package/dist/chains/sui/index.mjs +5 -529
  40. package/dist/chains/sui/index.mjs.map +1 -1
  41. package/dist/chunk-5T6KPH7A.mjs +1082 -0
  42. package/dist/chunk-5T6KPH7A.mjs.map +1 -0
  43. package/dist/chunk-72ZA3OYQ.mjs +20 -0
  44. package/dist/chunk-72ZA3OYQ.mjs.map +1 -0
  45. package/dist/chunk-EFIURACP.mjs +438 -0
  46. package/dist/chunk-EFIURACP.mjs.map +1 -0
  47. package/dist/chunk-F3YAGZSW.mjs +269 -0
  48. package/dist/chunk-F3YAGZSW.mjs.map +1 -0
  49. package/dist/chunk-GWJRKDSA.mjs +549 -0
  50. package/dist/chunk-GWJRKDSA.mjs.map +1 -0
  51. package/dist/chunk-M3MM4YMF.mjs +417 -0
  52. package/dist/chunk-M3MM4YMF.mjs.map +1 -0
  53. package/dist/chunk-N4A2RMUN.mjs +216 -0
  54. package/dist/chunk-N4A2RMUN.mjs.map +1 -0
  55. package/dist/chunk-NUWSMJFJ.mjs +179 -0
  56. package/dist/chunk-NUWSMJFJ.mjs.map +1 -0
  57. package/dist/chunk-OVMMTL6H.mjs +330 -0
  58. package/dist/chunk-OVMMTL6H.mjs.map +1 -0
  59. package/dist/chunk-PDHZ5X5O.mjs +565 -0
  60. package/dist/chunk-PDHZ5X5O.mjs.map +1 -0
  61. package/dist/chunk-PRHNGA4G.mjs +464 -0
  62. package/dist/chunk-PRHNGA4G.mjs.map +1 -0
  63. package/dist/chunk-Q5O3M5LP.mjs +422 -0
  64. package/dist/chunk-Q5O3M5LP.mjs.map +1 -0
  65. package/dist/chunk-QDO6NQ7P.mjs +840 -0
  66. package/dist/chunk-QDO6NQ7P.mjs.map +1 -0
  67. package/dist/chunk-QT4ZZ4GM.mjs +509 -0
  68. package/dist/chunk-QT4ZZ4GM.mjs.map +1 -0
  69. package/dist/chunk-USDA5JTN.mjs +1249 -0
  70. package/dist/chunk-USDA5JTN.mjs.map +1 -0
  71. package/dist/chunk-V636MIV3.mjs +52 -0
  72. package/dist/chunk-V636MIV3.mjs.map +1 -0
  73. package/dist/chunk-X7BZMSPQ.mjs +407 -0
  74. package/dist/chunk-X7BZMSPQ.mjs.map +1 -0
  75. package/dist/chunk-YCUJZ6Z7.mjs +829 -0
  76. package/dist/chunk-YCUJZ6Z7.mjs.map +1 -0
  77. package/dist/constants.d.mts +1 -1
  78. package/dist/constants.js +26 -12
  79. package/dist/constants.js.map +1 -1
  80. package/dist/constants.mjs +16 -375
  81. package/dist/constants.mjs.map +1 -1
  82. package/dist/index-DDalBhAm.d.mts +243 -0
  83. package/dist/index.d.mts +2508 -556
  84. package/dist/index.js +14576 -9628
  85. package/dist/index.js.map +1 -1
  86. package/dist/index.mjs +4108 -7840
  87. package/dist/index.mjs.map +1 -1
  88. package/dist/passkey.d.mts +182 -0
  89. package/dist/passkey.js +914 -0
  90. package/dist/passkey.js.map +1 -0
  91. package/dist/passkey.mjs +15 -0
  92. package/dist/passkey.mjs.map +1 -0
  93. package/dist/payload.js.map +1 -1
  94. package/dist/payload.mjs +25 -244
  95. package/dist/payload.mjs.map +1 -1
  96. package/dist/portfolio-V347KZOL.mjs +13 -0
  97. package/dist/portfolio-V347KZOL.mjs.map +1 -0
  98. package/dist/queries/index.js +145 -12
  99. package/dist/queries/index.js.map +1 -1
  100. package/dist/queries/index.mjs +14 -1496
  101. package/dist/queries/index.mjs.map +1 -1
  102. package/dist/{types-FJL7j6gQ.d.ts → types-B7V5VNbO.d.mts} +6 -2
  103. package/dist/{types-ChIsqCiw.d.mts → types-DP2CQT8p.d.mts} +12 -1
  104. package/dist/types.d.mts +16 -0
  105. package/dist/types.js.map +1 -1
  106. package/dist/utils.js +25 -11
  107. package/dist/utils.js.map +1 -1
  108. package/dist/utils.mjs +19 -371
  109. package/dist/utils.mjs.map +1 -1
  110. package/dist/wormhole.js.map +1 -1
  111. package/dist/wormhole.mjs +25 -397
  112. package/dist/wormhole.mjs.map +1 -1
  113. package/package.json +28 -3
  114. package/scripts/patch-noble-curves.js +78 -0
  115. package/dist/chains/aptos/index.d.ts +0 -145
  116. package/dist/chains/evm/index.d.ts +0 -5
  117. package/dist/chains/solana/index.d.ts +0 -116
  118. package/dist/chains/starknet/index.d.ts +0 -172
  119. package/dist/chains/sui/index.d.ts +0 -182
  120. package/dist/constants.d.ts +0 -150
  121. package/dist/index-0NXfbk0z.d.ts +0 -637
  122. package/dist/index-D0dLVjTA.d.mts +0 -637
  123. package/dist/index.d.ts +0 -3123
  124. package/dist/payload.d.ts +0 -125
  125. package/dist/queries/index.d.ts +0 -148
  126. package/dist/types-ChIsqCiw.d.ts +0 -565
  127. package/dist/types-FJL7j6gQ.d.mts +0 -172
  128. package/dist/types.d.ts +0 -407
  129. package/dist/utils.d.ts +0 -81
  130. package/dist/wormhole.d.ts +0 -167
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/wormhole.ts","../src/constants.ts"],"sourcesContent":["/**\n * Veridex Protocol SDK - Wormhole Utilities\n * \n * Functions for fetching VAAs, parsing messages, and interacting with Wormhole\n * \n * This module integrates with the official @wormhole-foundation/sdk patterns for\n * better chain abstraction and reliability, while providing Veridex-specific\n * utilities for payload handling and VAA management.\n */\n\nimport { ethers } from 'ethers';\nimport type { VAA, VAASignature, VeridexPayload } from './types.js';\nimport { WORMHOLE_API } from './constants.js';\n\n// ============================================================================\n// Constants\n// ============================================================================\n\n/**\n * Wormhole Consistency Levels\n * @see https://docs.wormhole.com/wormhole/reference/glossary#consistency-level\n */\nexport const CONSISTENCY_LEVELS = {\n /** Finalized - Wait for block finality (most secure) */\n FINALIZED: 200,\n /** Instant - No wait for finality (fastest, less secure) */\n INSTANT: 201,\n /** Safe - Standard finality (deprecated, use FINALIZED) */\n SAFE: 200,\n} as const;\n\n/**\n * Guardian network configuration\n */\nexport const GUARDIAN_CONFIG = {\n /** Total number of guardians in mainnet */\n MAINNET_GUARDIAN_COUNT: 19,\n /** Required signatures for mainnet quorum (13/19) */\n MAINNET_QUORUM: 13,\n /** Total number of guardians in testnet */\n TESTNET_GUARDIAN_COUNT: 1,\n /** Required signatures for testnet quorum */\n TESTNET_QUORUM: 1,\n} as const;\n\n// ============================================================================\n// Types\n// ============================================================================\n\nexport interface FetchVAAOptions {\n testnet?: boolean;\n maxRetries?: number;\n retryDelayMs?: number;\n onRetry?: (attempt: number, maxRetries: number) => void;\n}\n\nexport interface WaitForSignaturesOptions {\n testnet?: boolean;\n requiredSignatures?: number;\n maxWaitMs?: number;\n checkIntervalMs?: number;\n onProgress?: (currentSignatures: number, required: number) => void;\n}\n\n// ============================================================================\n// VAA Fetching\n// ============================================================================\n\n/**\n * Fetch a VAA from Wormhole guardians by sequence number\n * \n * @example\n * ```ts\n * const vaa = await fetchVAA(\n * WORMHOLE_CHAIN_IDS.TESTNET.BASE_SEPOLIA,\n * '0x000...hubAddress',\n * 97n,\n * { testnet: true }\n * );\n * ```\n */\nexport async function fetchVAA(\n emitterChain: number,\n emitterAddress: string,\n sequence: bigint,\n options: FetchVAAOptions = {}\n): Promise<string> {\n const {\n testnet = true,\n maxRetries = 30,\n retryDelayMs = 2000,\n onRetry,\n } = options;\n\n const apiBase = testnet ? WORMHOLE_API.TESTNET : WORMHOLE_API.MAINNET;\n const normalizedEmitter = normalizeEmitterAddress(emitterAddress);\n const url = `${apiBase}/api/v1/vaas/${emitterChain}/${normalizedEmitter}/${sequence.toString()}`;\n\n for (let i = 0; i < maxRetries; i++) {\n try {\n const response = await fetch(url);\n\n if (response.ok) {\n const data = await response.json() as { data?: { vaa?: string } };\n if (data.data?.vaa) {\n return data.data.vaa;\n }\n }\n\n if (i < maxRetries - 1) {\n onRetry?.(i + 1, maxRetries);\n await sleep(retryDelayMs);\n }\n } catch {\n if (i < maxRetries - 1) {\n onRetry?.(i + 1, maxRetries);\n await sleep(retryDelayMs);\n }\n }\n }\n\n throw new Error(`Failed to fetch VAA after ${maxRetries} attempts`);\n}\n\n/**\n * Fetch VAA by transaction hash using operations API\n * This is more reliable than the transactions API when sequence numbers don't match\n */\nexport async function fetchVAAByTxHash(\n txHash: string,\n options: {\n testnet?: boolean;\n maxRetries?: number;\n retryDelayMs?: number;\n onRetry?: (attempt: number, maxRetries: number) => void;\n } = {}\n): Promise<string> {\n const {\n testnet = true,\n maxRetries = 60,\n retryDelayMs = 3000,\n onRetry,\n } = options;\n\n const apiBase = testnet ? WORMHOLE_API.TESTNET : WORMHOLE_API.MAINNET;\n // Remove 0x prefix if present for the API\n const cleanTxHash = txHash.replace(/^0x/, '');\n const url = `${apiBase}/api/v1/operations?txHash=${cleanTxHash}`;\n\n for (let i = 0; i < maxRetries; i++) {\n try {\n const response = await fetch(url);\n\n if (response.ok) {\n const data = await response.json() as { \n operations?: Array<{ \n vaa?: { raw?: string }; \n sequence?: string;\n }>;\n };\n if (data.operations && data.operations.length > 0) {\n const operation = data.operations[0];\n if (operation.vaa?.raw) {\n return operation.vaa.raw;\n }\n }\n }\n\n if (i < maxRetries - 1) {\n onRetry?.(i + 1, maxRetries);\n await sleep(retryDelayMs);\n }\n } catch {\n if (i < maxRetries - 1) {\n onRetry?.(i + 1, maxRetries);\n await sleep(retryDelayMs);\n }\n }\n }\n\n throw new Error(`Failed to fetch VAA after ${maxRetries} attempts`);\n}\n\n/**\n * Fetch VAA by transaction hash using transactions API (fallback)\n */\nexport async function fetchVAAByTxHashFallback(\n txHash: string,\n options: {\n testnet?: boolean;\n maxRetries?: number;\n retryDelayMs?: number;\n onRetry?: (attempt: number, maxRetries: number) => void;\n } = {}\n): Promise<string> {\n const {\n testnet = true,\n maxRetries = 30,\n retryDelayMs = 2000,\n onRetry,\n } = options;\n\n const apiBase = testnet ? WORMHOLE_API.TESTNET : WORMHOLE_API.MAINNET;\n const url = `${apiBase}/api/v1/transactions/${txHash}`;\n\n for (let i = 0; i < maxRetries; i++) {\n try {\n const response = await fetch(url);\n\n if (response.ok) {\n const data = await response.json() as { data?: { globalTx?: { originTx?: { vaaId?: string } } } };\n if (data.data?.globalTx?.originTx?.vaaId) {\n const vaaId = data.data.globalTx.originTx.vaaId;\n const vaaUrl = `${apiBase}/api/v1/vaas/${vaaId}`;\n const vaaResponse = await fetch(vaaUrl);\n\n if (vaaResponse.ok) {\n const vaaData = await vaaResponse.json() as { data?: { vaa?: string } };\n if (vaaData.data?.vaa) {\n return vaaData.data.vaa;\n }\n }\n }\n }\n\n if (i < maxRetries - 1) {\n onRetry?.(i + 1, maxRetries);\n await sleep(retryDelayMs);\n }\n } catch {\n if (i < maxRetries - 1) {\n onRetry?.(i + 1, maxRetries);\n await sleep(retryDelayMs);\n }\n }\n }\n\n throw new Error(`Failed to fetch VAA after ${maxRetries} attempts`);\n}\n\n// ============================================================================\n// VAA Parsing\n// ============================================================================\n\n/**\n * Parse a base64-encoded VAA into its components\n */\nexport function parseVAA(vaaBase64: string): VAA {\n const vaaBytes = Buffer.from(vaaBase64, 'base64');\n return parseVAABytes(vaaBytes);\n}\n\n/**\n * Parse raw VAA bytes into its components\n */\nexport function parseVAABytes(vaaBytes: Buffer): VAA {\n let offset = 0;\n\n // Version (1 byte)\n const version = vaaBytes.readUInt8(offset);\n offset += 1;\n\n // Guardian set index (4 bytes)\n const guardianSetIndex = vaaBytes.readUInt32BE(offset);\n offset += 4;\n\n // Number of signatures (1 byte)\n const numSignatures = vaaBytes.readUInt8(offset);\n offset += 1;\n\n // Parse signatures (66 bytes each: 1 guardian index + 65 signature)\n const signatures: VAASignature[] = [];\n for (let i = 0; i < numSignatures; i++) {\n const guardianIndex = vaaBytes.readUInt8(offset);\n offset += 1;\n const signature = '0x' + vaaBytes.subarray(offset, offset + 65).toString('hex');\n offset += 65;\n signatures.push({ guardianIndex, signature });\n }\n\n // Mark the start of the body (for hash calculation)\n const bodyOffset = offset;\n\n // Timestamp (4 bytes)\n const timestamp = vaaBytes.readUInt32BE(offset);\n offset += 4;\n\n // Nonce (4 bytes)\n const nonce = vaaBytes.readUInt32BE(offset);\n offset += 4;\n\n // Emitter chain (2 bytes)\n const emitterChain = vaaBytes.readUInt16BE(offset);\n offset += 2;\n\n // Emitter address (32 bytes)\n const emitterAddress = '0x' + vaaBytes.subarray(offset, offset + 32).toString('hex');\n offset += 32;\n\n // Sequence (8 bytes)\n const sequence = vaaBytes.readBigUInt64BE(offset);\n offset += 8;\n\n // Consistency level (1 byte)\n const consistencyLevel = vaaBytes.readUInt8(offset);\n offset += 1;\n\n // Payload (remaining bytes)\n const payload = '0x' + vaaBytes.subarray(offset).toString('hex');\n\n // Calculate VAA body hash (used for verification on destination chains)\n const body = vaaBytes.subarray(bodyOffset);\n const hash = ethers.keccak256(ethers.keccak256(body));\n\n return {\n version,\n guardianSetIndex,\n signatures,\n timestamp,\n nonce,\n emitterChain,\n emitterAddress,\n sequence,\n consistencyLevel,\n payload,\n hash,\n };\n}\n\n/**\n * Parse a Veridex-specific payload from a VAA\n */\nexport function parseVeridexPayload(payloadHex: string): VeridexPayload {\n const payload = Buffer.from(payloadHex.replace('0x', ''), 'hex');\n let offset = 0;\n\n // Version (1 byte)\n const version = payload.readUInt8(offset);\n offset += 1;\n\n // User key hash (32 bytes)\n const userKeyHash = '0x' + payload.subarray(offset, offset + 32).toString('hex');\n offset += 32;\n\n // Target chain (2 bytes)\n const targetChain = payload.readUInt16BE(offset);\n offset += 2;\n\n // Nonce (32 bytes)\n const nonce = BigInt('0x' + payload.subarray(offset, offset + 32).toString('hex'));\n offset += 32;\n\n // Public key X (32 bytes)\n const publicKeyX = BigInt('0x' + payload.subarray(offset, offset + 32).toString('hex'));\n offset += 32;\n\n // Public key Y (32 bytes)\n const publicKeyY = BigInt('0x' + payload.subarray(offset, offset + 32).toString('hex'));\n offset += 32;\n\n // Action payload (remaining bytes)\n const actionPayload = '0x' + payload.subarray(offset).toString('hex');\n\n return {\n version,\n userKeyHash,\n targetChain,\n nonce,\n publicKeyX,\n publicKeyY,\n actionPayload,\n };\n}\n\n// ============================================================================\n// VAA Encoding\n// ============================================================================\n\n/**\n * Encode a VAA back to bytes for on-chain submission\n */\nexport function encodeVAAToBytes(vaaBase64: string): string {\n const vaaBytes = Buffer.from(vaaBase64, 'base64');\n return '0x' + vaaBytes.toString('hex');\n}\n\n/**\n * Encode VAA to bytes for Solana (returns Uint8Array)\n */\nexport function encodeVAAForSolana(vaaBase64: string): Uint8Array {\n return new Uint8Array(Buffer.from(vaaBase64, 'base64'));\n}\n\n// ============================================================================\n// Address Utilities\n// ============================================================================\n\n/**\n * Normalize an address to a 32-byte Wormhole emitter address format\n */\nexport function normalizeEmitterAddress(address: string): string {\n let hex = address.replace('0x', '');\n while (hex.length < 64) {\n hex = '0' + hex;\n }\n return hex;\n}\n\n/**\n * Convert a 32-byte emitter address back to a 20-byte EVM address\n */\nexport function emitterToEvmAddress(emitterHex: string): string {\n const hex = emitterHex.replace('0x', '');\n return '0x' + hex.slice(-40);\n}\n\n// ============================================================================\n// Transaction Utilities\n// ============================================================================\n\n/**\n * Extract the VAA sequence from a transaction receipt\n */\nexport async function getSequenceFromTxReceipt(\n provider: ethers.Provider,\n txHash: string,\n wormholeCoreBridge: string\n): Promise<bigint> {\n const receipt = await provider.getTransactionReceipt(txHash);\n if (!receipt) {\n throw new Error(`Transaction receipt not found: ${txHash}`);\n }\n\n const LOG_MESSAGE_PUBLISHED_TOPIC = ethers.id(\n 'LogMessagePublished(address,uint64,uint32,bytes,uint8)'\n );\n\n for (const log of receipt.logs) {\n if (log.address.toLowerCase() === wormholeCoreBridge.toLowerCase()) {\n if (log.topics[0] === LOG_MESSAGE_PUBLISHED_TOPIC && log.topics[1]) {\n const sequence = BigInt(log.topics[1]);\n return sequence;\n }\n }\n }\n\n throw new Error('LogMessagePublished event not found in transaction');\n}\n\n/**\n * Wait for a Wormhole message to be signed by guardians\n * \n * @example\n * ```ts\n * const vaa = await waitForGuardianSignatures(\n * WORMHOLE_CHAIN_IDS.TESTNET.BASE_SEPOLIA,\n * hubEmitter,\n * 97n,\n * {\n * testnet: true,\n * onProgress: (current, required) => console.log(`${current}/${required} signatures`)\n * }\n * );\n * ```\n */\nexport async function waitForGuardianSignatures(\n emitterChain: number,\n emitterAddress: string,\n sequence: bigint,\n options: WaitForSignaturesOptions = {}\n): Promise<VAA> {\n const {\n testnet = true,\n requiredSignatures = testnet ? GUARDIAN_CONFIG.TESTNET_QUORUM : GUARDIAN_CONFIG.MAINNET_QUORUM,\n maxWaitMs = 120000,\n checkIntervalMs = 5000,\n onProgress,\n } = options;\n\n const startTime = Date.now();\n\n while (Date.now() - startTime < maxWaitMs) {\n try {\n const vaaBase64 = await fetchVAA(emitterChain, emitterAddress, sequence, {\n testnet,\n maxRetries: 1,\n retryDelayMs: 0,\n });\n const vaa = parseVAA(vaaBase64);\n\n onProgress?.(vaa.signatures.length, requiredSignatures);\n\n if (vaa.signatures.length >= requiredSignatures) {\n return vaa;\n }\n } catch {\n // VAA not available yet, continue waiting\n }\n\n await sleep(checkIntervalMs);\n }\n\n throw new Error(`Timeout waiting for guardian signatures after ${maxWaitMs / 1000}s`);\n}\n\n// ============================================================================\n// Wormhole Core Bridge Addresses\n// ============================================================================\n\n/**\n * Get the Wormhole Core Bridge contract address for a chain\n */\nexport function getWormholeCoreBridge(wormholeChainId: number, testnet = true): string {\n const testnetBridges: Record<number, string> = {\n 10004: '0x79A1027a6A159502049F10906D333EC57E95F083', // Base Sepolia\n 10005: '0x31377888146f3253211EFEf5c676D41ECe7D58Fe', // Optimism Sepolia\n 10003: '0x6b9C8671cdDC8dEab9c719bB87cBd3e782bA6a35', // Arbitrum Sepolia\n 1: '3u8hJUVTA4jH1wYAyUur7FFZVQ8H635K3tSHHF4ssjQ5', // Solana Devnet\n 22: '0x5bc11445584a763c1fa7ed39081f1b920954da14e04b32440cba863d03e19625', // Aptos Testnet\n 21: '0x31358d198147da50db32eda2562951d53973a0c0ad5ed738e9b17d88b213d790', // Sui Testnet\n };\n\n const mainnetBridges: Record<number, string> = {\n 2: '0x98f3c9e6E3fAce36bAAd05FE09d375Ef1464288B', // Ethereum\n 30: '0xbebdb6C8ddC678FfA9f8748f85C815C556Dd8ac6', // Base\n 24: '0xEe91C335eab126dF5fDB3797EA9d6aD93aeC9722', // Optimism\n 23: '0xa5f208e072434bC67592E4C49C1B991BA79BCA46', // Arbitrum\n 5: '0x7A4B5a56256163F07b2C80A7cA55aBE66c4ec4d7', // Polygon\n 1: 'worm2ZoG2kUd4vFXhvjh93UUH596ayRfgQ2MgjNMTth', // Solana\n 22: '0x5bc11445584a763c1fa7ed39081f1b920954da14e04b32440cba863d03e19625', // Aptos\n 21: '0xaeab97f96cf9877fee2883315d459552b2b921edc16d7ceac6eab944dd88919c', // Sui\n };\n\n const bridges = testnet ? testnetBridges : mainnetBridges;\n return bridges[wormholeChainId] ?? '';\n}\n\n/**\n * Get the Wormhole Token Bridge contract address for a chain\n */\nexport function getWormholeTokenBridge(wormholeChainId: number, testnet = true): string {\n const testnetBridges: Record<number, string> = {\n 10004: '0x86F55A04690fd7815A3D802bD587e83eA888B239', // Base Sepolia\n 10005: '0x99737Ec4B815d816c49A385943baf0380e75c0Ac', // Optimism Sepolia\n 10003: '0xC7A204bDBFe983FCD8d8E61D02b475D4073fF97e', // Arbitrum Sepolia\n };\n\n const mainnetBridges: Record<number, string> = {\n 2: '0x3ee18B2214AFF97000D974cf647E7C347E8fa585', // Ethereum\n 30: '0x8d2de8d2f73F1F4cAB472AC9A881C9b123C79627', // Base\n 24: '0x1D68124e65faFC907325e3EDbF8c4d84499DAa8b', // Optimism\n 23: '0x0b2402144Bb366A632D14B83F244D2e0e21bD39c', // Arbitrum\n 5: '0x5a58505a96D1dbf8dF91cB21B54419FC36e93fdE', // Polygon\n };\n\n const bridges = testnet ? testnetBridges : mainnetBridges;\n return bridges[wormholeChainId] ?? '';\n}\n\n/**\n * Get the Wormhole Relayer contract address for a chain\n */\nexport function getWormholeRelayer(wormholeChainId: number, testnet = true): string {\n const testnetRelayers: Record<number, string> = {\n 10004: '0x93BAD53DDfB6132b0aC8E37f6029163E63372cEE', // Base Sepolia\n 10005: '0x93BAD53DDfB6132b0aC8E37f6029163E63372cEE', // Optimism Sepolia\n 10003: '0x7B1bD7a6b4E61c2a123AC6BC2cbfC614437D0470', // Arbitrum Sepolia\n };\n\n const mainnetRelayers: Record<number, string> = {\n 2: '0x27428DD2d3DD32A4D7f7C497eAaa23130d894911', // Ethereum\n 30: '0x706F82e9bb5b0813501714Ab5974216704980e31', // Base\n 24: '0x27428DD2d3DD32A4D7f7C497eAaa23130d894911', // Optimism\n 23: '0x27428DD2d3DD32A4D7f7C497eAaa23130d894911', // Arbitrum\n 5: '0x27428DD2d3DD32A4D7f7C497eAaa23130d894911', // Polygon\n };\n\n const relayers = testnet ? testnetRelayers : mainnetRelayers;\n return relayers[wormholeChainId] ?? '';\n}\n\n/**\n * Check if a chain supports Wormhole Relayer\n */\nexport function supportsRelayer(wormholeChainId: number, testnet = true): boolean {\n return getWormholeRelayer(wormholeChainId, testnet) !== '';\n}\n\n/**\n * Get chain name from Wormhole chain ID\n */\nexport function getChainName(wormholeChainId: number): string {\n const names: Record<number, string> = {\n 1: 'Solana',\n 2: 'Ethereum',\n 4: 'BSC',\n 5: 'Polygon',\n 6: 'Avalanche',\n 10: 'Fantom',\n 21: 'Sui',\n 22: 'Aptos',\n 23: 'Arbitrum',\n 24: 'Optimism',\n 30: 'Base',\n 10002: 'Sepolia',\n 10003: 'Arbitrum Sepolia',\n 10004: 'Base Sepolia',\n 10005: 'Optimism Sepolia',\n };\n return names[wormholeChainId] ?? `Chain ${wormholeChainId}`;\n}\n\n// ============================================================================\n// VAA Validation\n// ============================================================================\n\n/**\n * Validate that a VAA has sufficient signatures for the given network\n */\nexport function hasQuorum(vaa: VAA, testnet = true): boolean {\n const required = testnet ? GUARDIAN_CONFIG.TESTNET_QUORUM : GUARDIAN_CONFIG.MAINNET_QUORUM;\n return vaa.signatures.length >= required;\n}\n\n/**\n * Validate VAA emitter matches expected source\n */\nexport function validateEmitter(\n vaa: VAA,\n expectedChain: number,\n expectedAddress: string\n): boolean {\n const normalizedExpected = '0x' + normalizeEmitterAddress(expectedAddress);\n return (\n vaa.emitterChain === expectedChain &&\n vaa.emitterAddress.toLowerCase() === normalizedExpected.toLowerCase()\n );\n}\n\n/**\n * Convert an EVM address to bytes32 format (for Wormhole)\n */\nexport function evmAddressToBytes32(address: string): string {\n const hex = address.replace('0x', '').toLowerCase();\n return '0x' + hex.padStart(64, '0');\n}\n\n// ============================================================================\n// Helpers\n// ============================================================================\n\nfunction sleep(ms: number): Promise<void> {\n return new Promise(resolve => setTimeout(resolve, ms));\n}\n","/**\n * Veridex Protocol SDK - Constants and Chain Configurations\n */\n\nimport type { ChainConfig } from './types.js';\n\n// ============================================================================\n// Action Type Constants\n// ============================================================================\n\nexport const ACTION_TYPES = {\n TRANSFER: 1,\n EXECUTE: 2,\n CONFIG: 3,\n BRIDGE: 4,\n} as const;\n\nexport const ACTION_TRANSFER = 1;\nexport const ACTION_EXECUTE = 2;\nexport const ACTION_CONFIG = 3;\nexport const ACTION_BRIDGE = 4;\n\n// Protocol version\nexport const PROTOCOL_VERSION = 1;\n\n// ============================================================================\n// Wormhole Chain IDs\n// ============================================================================\n\n/**\n * Wormhole Chain IDs organized by network\n * @see https://docs.wormhole.com/wormhole/reference/constants\n */\nexport const WORMHOLE_CHAIN_IDS = {\n MAINNET: {\n SOLANA: 1,\n ETHEREUM: 2,\n TERRA: 3,\n BSC: 4,\n POLYGON: 5,\n AVALANCHE: 6,\n OASIS: 7,\n ALGORAND: 8,\n AURORA: 9,\n FANTOM: 10,\n KARURA: 11,\n ACALA: 12,\n KLAYTN: 13,\n CELO: 14,\n NEAR: 15,\n MOONBEAM: 16,\n NEON: 17,\n TERRA2: 18,\n INJECTIVE: 19,\n OSMOSIS: 20,\n SUI: 21,\n APTOS: 22,\n ARBITRUM: 23,\n OPTIMISM: 24,\n GNOSIS: 25,\n PYTHNET: 26,\n XPLA: 28,\n BASE: 30,\n SEI: 32,\n ROOTSTOCK: 33,\n SCROLL: 34,\n MANTLE: 35,\n BLAST: 36,\n XLAYER: 37,\n LINEA: 38,\n BERACHAIN: 39,\n SEIEVM: 40,\n },\n TESTNET: {\n SOLANA_DEVNET: 1,\n GOERLI: 2,\n BSC_TESTNET: 4,\n POLYGON_MUMBAI: 5,\n AVALANCHE_FUJI: 6,\n FANTOM_TESTNET: 10,\n CELO_ALFAJORES: 14,\n MOONBASE_ALPHA: 16,\n SUI_TESTNET: 21,\n APTOS_TESTNET: 22,\n SEPOLIA: 10002,\n ARBITRUM_SEPOLIA: 10003,\n BASE_SEPOLIA: 10004,\n OPTIMISM_SEPOLIA: 10005,\n HOLESKY: 10006,\n POLYGON_SEPOLIA: 10007,\n SEI_ATLANTIC_2: 10066, // Sei Arctic-1 testnet (EVM)\n STARKNET_SEPOLIA: 50001, // Custom bridge (non-Wormhole, relayer-attested)\n },\n} as const;\n\n// Legacy flat exports for backward compatibility\nexport const WORMHOLE_CHAIN_IDS_FLAT = {\n // Mainnets\n SOLANA: 1,\n ETHEREUM: 2,\n TERRA: 3,\n BSC: 4,\n POLYGON: 5,\n AVALANCHE: 6,\n OASIS: 7,\n ALGORAND: 8,\n AURORA: 9,\n FANTOM: 10,\n KARURA: 11,\n ACALA: 12,\n KLAYTN: 13,\n CELO: 14,\n NEAR: 15,\n MOONBEAM: 16,\n NEON: 17,\n TERRA2: 18,\n INJECTIVE: 19,\n OSMOSIS: 20,\n SUI: 21,\n APTOS: 22,\n ARBITRUM: 23,\n OPTIMISM: 24,\n GNOSIS: 25,\n PYTHNET: 26,\n XPLA: 28,\n BASE: 30,\n SEI: 32,\n ROOTSTOCK: 33,\n SCROLL: 34,\n MANTLE: 35,\n BLAST: 36,\n XLAYER: 37,\n LINEA: 38,\n BERACHAIN: 39,\n SEIEVM: 40,\n\n // Testnets\n SOLANA_DEVNET: 1,\n GOERLI: 2,\n BSC_TESTNET: 4,\n POLYGON_MUMBAI: 5,\n AVALANCHE_FUJI: 6,\n FANTOM_TESTNET: 10,\n CELO_ALFAJORES: 14,\n MOONBASE_ALPHA: 16,\n SUI_TESTNET: 21,\n APTOS_TESTNET: 22,\n ARBITRUM_SEPOLIA: 10003,\n BASE_SEPOLIA: 10004,\n OPTIMISM_SEPOLIA: 10005,\n POLYGON_SEPOLIA: 10007,\n HOLESKY: 10006,\n STARKNET_SEPOLIA: 50001, // Custom bridge (non-Wormhole)\n} as const;\n\n// ============================================================================\n// Testnet Chain Configurations\n// ============================================================================\n\nexport const TESTNET_CHAINS: Record<string, ChainConfig> = {\n baseSepolia: {\n name: 'Base Sepolia',\n chainId: 84532,\n wormholeChainId: 10004,\n rpcUrl: 'https://sepolia.base.org', // Public CORS-friendly RPC\n explorerUrl: 'https://sepolia.basescan.org',\n isEvm: true,\n contracts: {\n hub: '0x66D87dE68327f48A099c5B9bE97020Feab9a7c82',\n vaultFactory: '0xCFaEb5652aa2Ee60b2229dC8895B4159749C7e53',\n vaultImplementation: '0x0d13367C16c6f0B24eD275CC67C7D9f42878285c',\n wormholeCoreBridge: '0x79A1027a6A159502049F10906D333EC57E95F083',\n tokenBridge: '0x86F55A04690fd7815A3D802bD587e83eA888B239',\n },\n },\n optimismSepolia: {\n name: 'Optimism Sepolia',\n chainId: 11155420,\n wormholeChainId: 10005,\n rpcUrl: 'https://sepolia.optimism.io',\n explorerUrl: 'https://sepolia-optimism.etherscan.io',\n isEvm: true,\n contracts: {\n vaultFactory: '0xA5653d54079ABeCe780F8d9597B2bc4B09fe464A',\n vaultImplementation: '0x8099b1406485d2255ff89Ce5Ea18520802AFC150',\n wormholeCoreBridge: '0x31377888146f3253211EFEf5c676D41ECe7D58Fe',\n tokenBridge: '0x99737Ec4B815d816c49A385943baf0380e75c0Ac',\n },\n },\n arbitrumSepolia: {\n name: 'Arbitrum Sepolia',\n chainId: 421614,\n wormholeChainId: 10003,\n rpcUrl: 'https://sepolia-rollup.arbitrum.io/rpc',\n explorerUrl: 'https://sepolia.arbiscan.io',\n isEvm: true,\n contracts: {\n vaultFactory: '0xd36D3D5DB59d78f1E33813490F72DABC15C9B07c',\n vaultImplementation: '0xB10ACf39eBF17fc33F722cBD955b7aeCB0611bc4',\n wormholeCoreBridge: '0x6b9C8671cdDC8dEab9c719bB87cBd3e782bA6a35',\n tokenBridge: '0xC7A204bDBFe983FCD8d8E61D02b475D4073fF97e',\n },\n },\n seiTestnet: {\n name: 'Sei Atlantic-2',\n chainId: 1328,\n wormholeChainId: 40,\n rpcUrl: 'https://evm-rpc-testnet.sei-apis.com',\n explorerUrl: 'https://seitrace.com/?chain=atlantic-2',\n isEvm: true,\n contracts: {\n vaultFactory: '0x07F608AFf6d63b68029488b726d895c4Bb593038',\n vaultImplementation: '0xD66153fccFB6731fB6c4944FbD607ba86A76a1f6',\n wormholeCoreBridge: '0x0000000000000000000000000000000000000000', // Mock - not yet deployed\n },\n },\n solanaDevnet: {\n name: 'Solana Devnet',\n chainId: 0,\n wormholeChainId: 1,\n rpcUrl: 'https://api.devnet.solana.com',\n explorerUrl: 'https://explorer.solana.com',\n isEvm: false,\n contracts: {\n hub: 'AnyXHsqq9c2BiW4WgBcj6Aye7Ua7a7L7iSuwpfJxECJM',\n wormholeCoreBridge: '3u8hJUVTA4jH1wYAyUur7FFZVQ8H635K3tSHHF4ssjQ5',\n tokenBridge: 'DZnkkTmCiFWfYTfT41X3Rd1kDgozqzxWaHqsw6W4x2oe',\n },\n },\n aptosTestnet: {\n name: 'Aptos Testnet',\n chainId: 0,\n wormholeChainId: 22,\n rpcUrl: 'https://fullnode.testnet.aptoslabs.com/v1',\n explorerUrl: 'https://explorer.aptoslabs.com',\n isEvm: false,\n contracts: {\n hub: '0x0237e04f74b991b5b6030a793779663033f4ff4a1682a9e66c1f41fc1ec3e2a4',\n wormholeCoreBridge: '0x5bc11445584a763c1fa7ed39081f1b920954da14e04b32440cba863d03e19625',\n tokenBridge: '0x576410486a2da45eee6c949c995670112ddf2fbeedab20350d506328eefc9d4f',\n },\n },\n suiTestnet: {\n name: 'Sui Testnet',\n chainId: 0,\n wormholeChainId: 21,\n rpcUrl: 'https://fullnode.testnet.sui.io:443',\n explorerUrl: 'https://suiscan.xyz/testnet',\n isEvm: false,\n contracts: {\n hub: '0x35e99fdbbc1cde7e093da6f9e758ba2c4a077904bd64caee2fa6db5e6c4e9e37',\n wormholeCoreBridge: '0x31358d198147da50db32eda2562951d53973a0c0ad5ed738e9b17d88b213d790',\n },\n },\n starknetSepolia: {\n name: 'Starknet Sepolia',\n chainId: 0, // Native Starknet chain ID (SN_SEPOLIA = 0x534e5f5345504f4c4941)\n wormholeChainId: 50001, // Custom chain ID (50000+ reserved for non-Wormhole chains)\n rpcUrl: 'https://starknet-sepolia.g.alchemy.com/starknet/version/rpc/v0_7/tsOnfTBZDKMXcUA26OED-',\n explorerUrl: 'https://sepolia.starkscan.co',\n isEvm: false,\n contracts: {\n // Starknet spoke contract\n hub: '0x68adcc730ed6c355200d00f763825448497b9cdf7936ca121711e078c88e811',\n // Custom bridge contract (NOT Wormhole)\n wormholeCoreBridge: '0x2c458c1ae64556482b05cc2d3ee5b032ed114d68429dda2062c9849a5a725f8',\n },\n // Hub chain ID that Starknet bridge validates (Base Sepolia = 10004)\n hubChainId: 10004,\n },\n};\n\n// ============================================================================\n// Mainnet Chain Configurations\n// ============================================================================\n\nexport const MAINNET_CHAINS: Record<string, ChainConfig> = {\n ethereum: {\n name: 'Ethereum',\n chainId: 1,\n wormholeChainId: 2,\n rpcUrl: 'https://eth.llamarpc.com',\n explorerUrl: 'https://etherscan.io',\n isEvm: true,\n contracts: {\n wormholeCoreBridge: '0x98f3c9e6E3fAce36bAAd05FE09d375Ef1464288B',\n tokenBridge: '0x3ee18B2214AFF97000D974cf647E7C347E8fa585',\n },\n },\n base: {\n name: 'Base',\n chainId: 8453,\n wormholeChainId: 30,\n rpcUrl: 'https://mainnet.base.org',\n explorerUrl: 'https://basescan.org',\n isEvm: true,\n contracts: {\n wormholeCoreBridge: '0xbebdb6C8ddC678FfA9f8748f85C815C556Dd8ac6',\n tokenBridge: '0x8d2de8d2f73F1F4cAB472AC9A881C9b123C79627',\n },\n },\n optimism: {\n name: 'Optimism',\n chainId: 10,\n wormholeChainId: 24,\n rpcUrl: 'https://mainnet.optimism.io',\n explorerUrl: 'https://optimistic.etherscan.io',\n isEvm: true,\n contracts: {\n wormholeCoreBridge: '0xEe91C335eab126dF5fDB3797EA9d6aD93aeC9722',\n tokenBridge: '0x1D68124e65faFC907325e3EDbF8c4d84499DAa8b',\n },\n },\n arbitrum: {\n name: 'Arbitrum',\n chainId: 42161,\n wormholeChainId: 23,\n rpcUrl: 'https://arb1.arbitrum.io/rpc',\n explorerUrl: 'https://arbiscan.io',\n isEvm: true,\n contracts: {\n wormholeCoreBridge: '0xa5f208e072434bC67592E4C49C1B991BA79BCA46',\n tokenBridge: '0x0b2402144Bb366A632D14B83F244D2e0e21bD39c',\n },\n },\n polygon: {\n name: 'Polygon',\n chainId: 137,\n wormholeChainId: 5,\n rpcUrl: 'https://polygon-rpc.com',\n explorerUrl: 'https://polygonscan.com',\n isEvm: true,\n contracts: {\n wormholeCoreBridge: '0x7A4B5a56256163F07b2C80A7cA55aBE66c4ec4d7',\n tokenBridge: '0x5a58505a96D1dbf8dF91cB21B54419FC36e93fdE',\n },\n },\n solana: {\n name: 'Solana',\n chainId: 0,\n wormholeChainId: 1,\n rpcUrl: 'https://api.mainnet-beta.solana.com',\n explorerUrl: 'https://explorer.solana.com',\n isEvm: false,\n contracts: {\n wormholeCoreBridge: 'worm2ZoG2kUd4vFXhvjh93UUH596ayRfgQ2MgjNMTth',\n tokenBridge: 'wormDTUJ6AWPNvk59vGQbDvGJmqbDTdgWgAqcLBCgUb',\n },\n },\n aptos: {\n name: 'Aptos',\n chainId: 0,\n wormholeChainId: 22,\n rpcUrl: 'https://fullnode.mainnet.aptoslabs.com/v1',\n explorerUrl: 'https://explorer.aptoslabs.com',\n isEvm: false,\n contracts: {\n wormholeCoreBridge: '0x5bc11445584a763c1fa7ed39081f1b920954da14e04b32440cba863d03e19625',\n tokenBridge: '0x576410486a2da45eee6c949c995670112ddf2fbeedab20350d506328eefc9d4f',\n },\n },\n sui: {\n name: 'Sui',\n chainId: 0,\n wormholeChainId: 21,\n rpcUrl: 'https://fullnode.mainnet.sui.io:443',\n explorerUrl: 'https://suiscan.xyz/mainnet',\n isEvm: false,\n contracts: {\n wormholeCoreBridge: '0xaeab97f96cf9877fee2883315d459552b2b921edc16d7ceac6eab944dd88919c',\n },\n },\n};\n\n// ============================================================================\n// Wormhole API Endpoints\n// ============================================================================\n\nexport const WORMHOLE_API = {\n MAINNET: 'https://api.wormholescan.io',\n TESTNET: 'https://api.testnet.wormholescan.io',\n GUARDIAN_RPC_MAINNET: 'https://wormhole-v2-mainnet-api.certus.one',\n GUARDIAN_RPC_TESTNET: 'https://wormhole-v2-testnet-api.certus.one',\n} as const;\n\n// ============================================================================\n// Hub Contract ABI (minimal)\n// ============================================================================\n\nexport const HUB_ABI = [\n 'function authenticateAndDispatch((bytes authenticatorData, string clientDataJSON, uint256 challengeIndex, uint256 typeIndex, uint256 r, uint256 s) auth, uint256 publicKeyX, uint256 publicKeyY, uint16 targetChain, bytes actionPayload) external payable returns (uint64 sequence)',\n 'function authenticateRawAndDispatch(uint256 r, uint256 s, bytes32 messageHash, uint256 publicKeyX, uint256 publicKeyY, uint16 targetChain, bytes actionPayload, uint256 nonce) external payable returns (uint64 sequence)',\n 'function getNonce(bytes32 userKeyHash) external view returns (uint256)',\n 'function encodeTransferAction(address token, address recipient, uint256 amount) external pure returns (bytes)',\n 'function encodeExecuteAction(address target, uint256 value, bytes data) external pure returns (bytes)',\n 'function encodeBridgeAction(bytes32 token, uint256 amount, uint16 targetChain, bytes32 recipient) external pure returns (bytes)',\n 'function messageFee() external view returns (uint256)',\n 'event Dispatched(bytes32 indexed userKeyHash, uint16 targetChain, uint256 nonce, uint64 sequence, bytes actionPayload)',\n] as const;\n\n// ============================================================================\n// Vault Factory ABI (minimal)\n// ============================================================================\n\nexport const VAULT_FACTORY_ABI = [\n 'function createVault(bytes32 userKeyHash) external returns (address)',\n 'function getVault(bytes32 userKeyHash) external view returns (address)',\n 'function vaultExists(bytes32 userKeyHash) external view returns (bool)',\n 'event VaultCreated(bytes32 indexed userKeyHash, address vault)',\n] as const;\n\n// ============================================================================\n// Vault ABI (minimal)\n// ============================================================================\n\nexport const VAULT_ABI = [\n 'function execute(address target, uint256 value, bytes data) external returns (bytes)',\n 'function executeFromHub(bytes32 vaaHash, uint16 emitterChain, bytes32 emitterAddress, bytes payload) external',\n 'function owner() external view returns (bytes32)',\n 'function hub() external view returns (address)',\n 'receive() external payable',\n] as const;\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@veridex/sdk",
3
- "version": "1.0.0-beta.8",
3
+ "version": "1.0.1",
4
4
  "description": "Veridex Protocol SDK - Client library for Passkey-based cross-chain authentication",
5
5
  "author": "Veridex Protocol <team@veridex.network>",
6
6
  "license": "MIT",
@@ -18,6 +18,7 @@
18
18
  "sideEffects": false,
19
19
  "files": [
20
20
  "dist",
21
+ "scripts",
21
22
  "README.md",
22
23
  "CHANGELOG.md",
23
24
  "LICENSE"
@@ -78,13 +79,34 @@
78
79
  "import": "./dist/chains/starknet/index.mjs",
79
80
  "require": "./dist/chains/starknet/index.js"
80
81
  },
82
+ "./chains/stacks": {
83
+ "types": "./dist/chains/stacks/index.d.ts",
84
+ "import": "./dist/chains/stacks/index.mjs",
85
+ "require": "./dist/chains/stacks/index.js"
86
+ },
87
+ "./chains/avalanche": {
88
+ "types": "./dist/chains/avalanche/index.d.ts",
89
+ "import": "./dist/chains/avalanche/index.mjs",
90
+ "require": "./dist/chains/avalanche/index.js"
91
+ },
92
+ "./passkey": {
93
+ "types": "./dist/passkey.d.ts",
94
+ "import": "./dist/passkey.mjs",
95
+ "require": "./dist/passkey.js"
96
+ },
81
97
  "./queries": {
82
98
  "types": "./dist/queries/index.d.ts",
83
99
  "import": "./dist/queries/index.mjs",
84
100
  "require": "./dist/queries/index.js"
101
+ },
102
+ "./auth": {
103
+ "types": "./dist/auth/prepareAuth.d.ts",
104
+ "import": "./dist/auth/prepareAuth.mjs",
105
+ "require": "./dist/auth/prepareAuth.js"
85
106
  }
86
107
  },
87
108
  "scripts": {
109
+ "postinstall": "node scripts/patch-noble-curves.js",
88
110
  "build": "tsup",
89
111
  "dev": "tsup --watch",
90
112
  "test": "vitest run",
@@ -92,18 +114,20 @@
92
114
  "test:coverage": "vitest run --coverage",
93
115
  "lint": "eslint src/**/*.ts",
94
116
  "format": "prettier --write src/**/*.ts",
95
- "prepublishOnly": "npm run build && npm run test",
117
+ "prepublishOnly": "bun run build",
96
118
  "release:public": "cd ../.. && git subtree push --prefix=packages/sdk sdk-public main"
97
119
  },
98
120
  "dependencies": {
121
+ "@aptos-labs/ts-sdk": "^6.0.0",
122
+ "@noble/curves": "^1.9.0",
99
123
  "@mysten/bcs": "1.9.2",
100
124
  "@mysten/sui": "^1.0.0",
125
+ "@noble/hashes": "^1.5.0",
101
126
  "@simplewebauthn/browser": "^9.0.1",
102
127
  "@solana/spl-token": "^0.4.6",
103
128
  "@solana/web3.js": "^1.95.4",
104
129
  "@wormhole-foundation/sdk": "^0.10.0",
105
130
  "@wormhole-foundation/wormhole-query-sdk": "^0.0.14",
106
- "aptos": "^1.21.0",
107
131
  "axios": "^1.7.9",
108
132
  "ethers": "^6.11.1",
109
133
  "js-sha3": "^0.9.3",
@@ -136,6 +160,7 @@
136
160
  "aptos",
137
161
  "sui",
138
162
  "starknet",
163
+ "stacks",
139
164
  "authentication",
140
165
  "gasless",
141
166
  "session-keys",
@@ -0,0 +1,78 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * Patches @noble/curves to add nist.js export.
4
+ *
5
+ * @aptos-labs/ts-sdk imports from '@noble/curves/nist.js' but
6
+ * @noble/curves@1.2.0 doesn't export it. This script:
7
+ * 1. Creates nist.js (CJS) and esm/nist.js (ESM) shim files
8
+ * 2. Adds ./nist.js and ./nist to the package.json exports map
9
+ */
10
+ const fs = require('fs');
11
+ const path = require('path');
12
+
13
+ function findNobleDir() {
14
+ // Walk up from this script to find node_modules/@noble/curves
15
+ let dir = __dirname;
16
+ for (let i = 0; i < 10; i++) {
17
+ const candidate = path.join(dir, 'node_modules', '@noble', 'curves');
18
+ if (fs.existsSync(path.join(candidate, 'package.json'))) {
19
+ return candidate;
20
+ }
21
+ dir = path.dirname(dir);
22
+ }
23
+ return null;
24
+ }
25
+
26
+ const nobleDir = findNobleDir();
27
+ if (!nobleDir) {
28
+ console.log('[patch-noble-curves] @noble/curves not found, skipping');
29
+ process.exit(0);
30
+ }
31
+
32
+ const pkgPath = path.join(nobleDir, 'package.json');
33
+ const pkg = JSON.parse(fs.readFileSync(pkgPath, 'utf8'));
34
+
35
+ // Check if already patched
36
+ if (pkg.exports && pkg.exports['./nist.js']) {
37
+ console.log('[patch-noble-curves] Already patched, skipping');
38
+ process.exit(0);
39
+ }
40
+
41
+ // Create CJS shim
42
+ const cjsShim = `"use strict";
43
+ Object.defineProperty(exports, "__esModule", { value: true });
44
+ const p256_1 = require("./p256");
45
+ const p384_1 = require("./p384");
46
+ const p521_1 = require("./p521");
47
+ exports.p256 = p256_1.p256;
48
+ exports.p384 = p384_1.p384;
49
+ exports.p521 = p521_1.p521;
50
+ `;
51
+ fs.writeFileSync(path.join(nobleDir, 'nist.js'), cjsShim);
52
+
53
+ // Create ESM shim if esm dir exists
54
+ const esmDir = path.join(nobleDir, 'esm');
55
+ if (fs.existsSync(esmDir)) {
56
+ const esmShim = `export { p256 } from './p256.js';
57
+ export { p384 } from './p384.js';
58
+ export { p521 } from './p521.js';
59
+ `;
60
+ fs.writeFileSync(path.join(esmDir, 'nist.js'), esmShim);
61
+ }
62
+
63
+ // Patch exports
64
+ if (pkg.exports) {
65
+ pkg.exports['./nist.js'] = {
66
+ types: './p256.d.ts',
67
+ import: './esm/nist.js',
68
+ default: './nist.js'
69
+ };
70
+ pkg.exports['./nist'] = {
71
+ types: './p256.d.ts',
72
+ import: './esm/nist.js',
73
+ default: './nist.js'
74
+ };
75
+ fs.writeFileSync(pkgPath, JSON.stringify(pkg, null, 2) + '\n');
76
+ }
77
+
78
+ console.log('[patch-noble-curves] Patched @noble/curves with nist.js exports');
@@ -1,145 +0,0 @@
1
- import { AptosClient as AptosClient$1, Types } from 'aptos';
2
- import { C as ChainClient, a as ChainConfig, T as TransferParams, E as ExecuteParams, B as BridgeParams, W as WebAuthnSignature, D as DispatchResult, V as VaultCreationResult } from '../../types-ChIsqCiw.js';
3
-
4
- /**
5
- * Veridex Protocol SDK - Aptos Chain Client
6
- *
7
- * Implementation of ChainClient interface for Aptos blockchain
8
- */
9
-
10
- interface AptosClientConfig {
11
- wormholeChainId: number;
12
- rpcUrl: string;
13
- moduleAddress: string;
14
- wormholeCoreBridge: string;
15
- tokenBridge: string;
16
- network?: 'mainnet' | 'testnet' | 'devnet';
17
- }
18
- /**
19
- * Aptos implementation of the ChainClient interface
20
- */
21
- declare class AptosClient implements ChainClient {
22
- private config;
23
- private client;
24
- private moduleAddress;
25
- constructor(config: AptosClientConfig);
26
- getConfig(): ChainConfig;
27
- getNonce(userKeyHash: string): Promise<bigint>;
28
- getMessageFee(): Promise<bigint>;
29
- buildTransferPayload(params: TransferParams): Promise<string>;
30
- buildExecutePayload(params: ExecuteParams): Promise<string>;
31
- buildBridgePayload(params: BridgeParams): Promise<string>;
32
- dispatch(signature: WebAuthnSignature, publicKeyX: bigint, publicKeyY: bigint, targetChain: number, actionPayload: string, nonce: bigint, signer: any): Promise<DispatchResult>;
33
- /**
34
- * Dispatch an action via relayer (gasless)
35
- * Note: On Aptos, this still goes through the Hub chain
36
- * Aptos is a spoke-only chain in Veridex architecture
37
- */
38
- dispatchGasless(signature: WebAuthnSignature, publicKeyX: bigint, publicKeyY: bigint, targetChain: number, actionPayload: string, nonce: bigint, relayerUrl: string): Promise<DispatchResult>;
39
- /**
40
- * Get vault address from on-chain VaultRegistry.
41
- * Queries the get_vault_address view function which looks up the vault in the registry.
42
- */
43
- getVaultAddress(userKeyHash: string): Promise<string | null>;
44
- /**
45
- * @deprecated Use getVaultAddress() instead - this method uses incorrect address derivation.
46
- * On Aptos, vaults are created as named objects by the relayer, not resource accounts.
47
- * The vault address depends on which relayer created it, so must be queried on-chain.
48
- */
49
- computeVaultAddress(userKeyHash: string): string;
50
- private computeVaultAddressFromHash;
51
- /**
52
- * Convert hex string to Uint8Array (browser-compatible)
53
- */
54
- private hexToBytes;
55
- vaultExists(userKeyHash: string): Promise<boolean>;
56
- createVault(userKeyHash: string, signer: any): Promise<VaultCreationResult>;
57
- createVaultSponsored?(userKeyHash: string, sponsorPrivateKey: string, rpcUrl?: string): Promise<VaultCreationResult>;
58
- /**
59
- * Create a vault via the relayer (sponsored/gasless)
60
- * This is the recommended way to create Aptos vaults
61
- *
62
- * The relayer will dispatch a vault creation action from Hub to Aptos spoke
63
- */
64
- createVaultViaRelayer(userKeyHash: string, relayerUrl: string): Promise<VaultCreationResult>;
65
- /**
66
- * Get vault info via relayer (includes existence check)
67
- */
68
- getVaultViaRelayer(userKeyHash: string, relayerUrl: string): Promise<{
69
- vaultAddress: string;
70
- exists: boolean;
71
- }>;
72
- estimateVaultCreationGas(userKeyHash: string): Promise<bigint>;
73
- getFactoryAddress(): string | undefined;
74
- getImplementationAddress(): string | undefined;
75
- /**
76
- * Get native APT balance
77
- */
78
- getNativeBalance(address: string): Promise<bigint>;
79
- /**
80
- * Get fungible asset (FA) or coin balance
81
- */
82
- getTokenBalance(tokenAddress: string, ownerAddress: string): Promise<bigint>;
83
- /**
84
- * Compute key hash from public key coordinates
85
- * Matches EVM keccak256(abi.encode(publicKeyX, publicKeyY))
86
- */
87
- private computeKeyHash;
88
- /**
89
- * Build message for signing (matches Hub chain format)
90
- */
91
- private buildMessage;
92
- /**
93
- * Get Aptos client instance for advanced usage
94
- */
95
- getClient(): AptosClient$1;
96
- /**
97
- * Get module address
98
- */
99
- getModuleAddress(): string;
100
- /**
101
- * Get current ledger version
102
- */
103
- getLedgerVersion(): Promise<bigint>;
104
- /**
105
- * Get transaction by hash
106
- */
107
- getTransaction(txHash: string): Promise<Types.Transaction>;
108
- /**
109
- * Wait for transaction confirmation
110
- */
111
- waitForTransaction(txHash: string, timeoutSecs?: number): Promise<Types.Transaction>;
112
- /**
113
- * Get vault resource for an owner
114
- *
115
- * @param ownerKeyHash - Owner's passkey hash (32 bytes as hex)
116
- * @returns Vault resource data or null if not found
117
- */
118
- getVaultResource(ownerKeyHash: string): Promise<{
119
- ownerKeyHash: string;
120
- authorizedSigners: string[];
121
- nonce: bigint;
122
- } | null>;
123
- /**
124
- * Get authorized signers for a vault
125
- *
126
- * @param ownerKeyHash - Owner's passkey hash (32 bytes as hex)
127
- * @returns Array of authorized signer key hashes
128
- */
129
- getAuthorizedSigners(ownerKeyHash: string): Promise<string[]>;
130
- /**
131
- * Check if a VAA has been processed (for replay protection)
132
- *
133
- * @param vaaHash - VAA hash as hex string
134
- * @returns Whether the VAA has been processed
135
- */
136
- isVaaProcessed(vaaHash: string): Promise<boolean>;
137
- /**
138
- * Check if protocol is paused
139
- *
140
- * @returns Whether the protocol is paused
141
- */
142
- isProtocolPaused(): Promise<boolean>;
143
- }
144
-
145
- export { AptosClient, type AptosClientConfig };
@@ -1,5 +0,0 @@
1
- export { a as EVMClient, b as EVMClientConfig, E as EVMHubClientAdapter } from '../../index-0NXfbk0z.js';
2
- import '../../types.js';
3
- import 'ethers';
4
- import '../../types-ChIsqCiw.js';
5
- import '../../types-FJL7j6gQ.js';
@@ -1,116 +0,0 @@
1
- import * as _solana_web3_js from '@solana/web3.js';
2
- import { Connection, PublicKey } from '@solana/web3.js';
3
- import { C as ChainClient, a as ChainConfig, T as TransferParams, E as ExecuteParams, B as BridgeParams, W as WebAuthnSignature, D as DispatchResult, V as VaultCreationResult } from '../../types-ChIsqCiw.js';
4
-
5
- interface SolanaClientConfig {
6
- wormholeChainId: number;
7
- rpcUrl: string;
8
- programId: string;
9
- wormholeCoreBridge: string;
10
- tokenBridge: string;
11
- network?: 'mainnet' | 'devnet' | 'testnet';
12
- commitment?: 'processed' | 'confirmed' | 'finalized';
13
- }
14
- /**
15
- * Solana implementation of the ChainClient interface
16
- */
17
- declare class SolanaClient implements ChainClient {
18
- private config;
19
- private connection;
20
- private programId;
21
- constructor(config: SolanaClientConfig);
22
- getConfig(): ChainConfig;
23
- getNonce(userKeyHash: string): Promise<bigint>;
24
- getMessageFee(): Promise<bigint>;
25
- buildTransferPayload(params: TransferParams): Promise<string>;
26
- buildExecutePayload(params: ExecuteParams): Promise<string>;
27
- buildBridgePayload(params: BridgeParams): Promise<string>;
28
- dispatch(signature: WebAuthnSignature, publicKeyX: bigint, publicKeyY: bigint, targetChain: number, actionPayload: string, nonce: bigint, signer: any): Promise<DispatchResult>;
29
- /**
30
- * Dispatch an action via relayer (gasless)
31
- * Note: On Solana, this still goes through the Hub chain
32
- * Solana is a spoke-only chain in Veridex architecture
33
- */
34
- dispatchGasless(signature: WebAuthnSignature, publicKeyX: bigint, publicKeyY: bigint, targetChain: number, actionPayload: string, nonce: bigint, relayerUrl: string): Promise<DispatchResult>;
35
- getVaultAddress(userKeyHash: string): Promise<string | null>;
36
- /**
37
- * Compute vault address using PDA (Program Derived Address)
38
- * Seeds: ["vault", userKeyHash]
39
- */
40
- computeVaultAddress(userKeyHash: string): string;
41
- private computeVaultAddressFromHash;
42
- vaultExists(userKeyHash: string): Promise<boolean>;
43
- createVault(userKeyHash: string, signer: any): Promise<VaultCreationResult>;
44
- createVaultSponsored?(userKeyHash: string, sponsorPrivateKey: string, rpcUrl?: string): Promise<VaultCreationResult>;
45
- /**
46
- * Create a vault via the relayer (sponsored/gasless)
47
- * This is the recommended way to create Solana vaults
48
- */
49
- createVaultViaRelayer(userKeyHash: string, relayerUrl: string): Promise<VaultCreationResult>;
50
- /**
51
- * Get vault info via relayer (includes existence check)
52
- */
53
- getVaultViaRelayer(userKeyHash: string, relayerUrl: string): Promise<{
54
- vaultAddress: string;
55
- exists: boolean;
56
- }>;
57
- estimateVaultCreationGas(userKeyHash: string): Promise<bigint>;
58
- getFactoryAddress(): string | undefined;
59
- getImplementationAddress(): string | undefined;
60
- /**
61
- * Get native SOL balance
62
- */
63
- getNativeBalance(address: string): Promise<bigint>;
64
- /**
65
- * Get SPL token balance
66
- */
67
- getTokenBalance(tokenAddress: string, ownerAddress: string): Promise<bigint>;
68
- /**
69
- * Compute key hash from public key coordinates
70
- * Matches EVM keccak256(abi.encode(publicKeyX, publicKeyY))
71
- */
72
- private computeKeyHash;
73
- /**
74
- * Build message for signing (matches Hub chain format)
75
- */
76
- private buildMessage;
77
- /**
78
- * Get connection instance for advanced usage
79
- */
80
- getConnection(): Connection;
81
- /**
82
- * Get program ID
83
- */
84
- getProgramId(): PublicKey;
85
- /**
86
- * Get current slot
87
- */
88
- getSlot(): Promise<number>;
89
- /**
90
- * Get transaction status
91
- */
92
- getTransaction(signature: string, commitment?: 'confirmed' | 'finalized'): Promise<_solana_web3_js.VersionedTransactionResponse | null>;
93
- /**
94
- * Check if a recovery VAA has been executed on this spoke
95
- *
96
- * @param vaaHash - Hash of the recovery VAA
97
- * @returns Whether the VAA has been processed
98
- */
99
- isRecoveryExecuted(vaaHash: string): Promise<boolean>;
100
- /**
101
- * Get vault owner after potential recovery
102
- *
103
- * @param vaultAddress - Vault address to check
104
- * @returns Current owner key hash
105
- */
106
- getVaultOwner(vaultAddress: string): Promise<string>;
107
- /**
108
- * Get authorized signers for a vault
109
- *
110
- * @param vaultAddress - Vault address to check
111
- * @returns Array of authorized signer key hashes
112
- */
113
- getAuthorizedSigners(vaultAddress: string): Promise<string[]>;
114
- }
115
-
116
- export { SolanaClient, type SolanaClientConfig };