@t2000/sdk 0.6.2 → 0.7.0

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.
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/constants.ts","../src/errors.ts","../src/utils/sui.ts","../src/wallet/keyManager.ts","../src/utils/format.ts","../src/wallet/send.ts","../src/wallet/balance.ts","../src/wallet/history.ts","../src/protocols/protocolFee.ts","../src/protocols/navi.ts","../src/protocols/yieldTracker.ts","../src/protocols/sentinel.ts","../src/adapters/registry.ts","../src/adapters/navi.ts","../src/protocols/cetus.ts","../src/adapters/cetus.ts","../src/adapters/suilend.ts","../src/utils/hashcash.ts","../src/gas/gasStation.ts","../src/gas/autoTopUp.ts","../src/gas/manager.ts","../src/t2000.ts","../src/utils/simulate.ts"],"names":["SuiJsonRpcClient","normalizeSuiAddress","isValidSuiAddress","resolve","homedir","scryptSync","randomBytes","createCipheriv","createDecipheriv","Ed25519Keypair","decodeSuiPrivateKey","access","mkdir","dirname","writeFile","readFile","Transaction","bcs","f","attack","AggregatorClient","Env","USDC_TYPE","MIN_HEALTH_FACTOR","CLOCK","normalizeStructTag","createHash","EventEmitter","keypair","hf","adapters"],"mappings":"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","file":"index.cjs","sourcesContent":["export const MIST_PER_SUI = 1_000_000_000n;\nexport const SUI_DECIMALS = 9;\nexport const USDC_DECIMALS = 6;\n\nexport const BPS_DENOMINATOR = 10_000n;\nexport const PRECISION = 1_000_000_000_000_000_000n;\n\nexport const MIN_DEPOSIT = 1_000_000n; // 1 USDC (6 decimals)\nexport const GAS_RESERVE_USDC = 1_000_000n; // $1 USDC reserved for gas\nexport const AUTO_TOPUP_THRESHOLD = 50_000_000n; // 0.05 SUI\nexport const AUTO_TOPUP_AMOUNT = 1_000_000n; // $1 USDC worth of SUI\nexport const AUTO_TOPUP_MIN_USDC = 2_000_000n; // $2 USDC minimum to trigger auto-topup\nexport const BOOTSTRAP_LIMIT = 10;\nexport const GAS_FEE_CEILING_USD = 0.05;\n\nexport const SAVE_FEE_BPS = 10n; // 0.1%\nexport const SWAP_FEE_BPS = 0n; // Free — Cetus already charges pool fees\nexport const BORROW_FEE_BPS = 5n; // 0.05%\n\nexport const CLOCK_ID = '0x6';\n\nexport const SUPPORTED_ASSETS = {\n USDC: {\n type: '0xdba34672e30cb065b1f93e3ab55318768fd6fef66c15942c9f7cb846e2f900e7::usdc::USDC',\n decimals: 6,\n symbol: 'USDC',\n },\n SUI: {\n type: '0x2::sui::SUI',\n decimals: 9,\n symbol: 'SUI',\n },\n} as const;\n\nexport type SupportedAsset = keyof typeof SUPPORTED_ASSETS;\n\nexport const T2000_PACKAGE_ID = process.env.T2000_PACKAGE_ID ?? '0xab92e9f1fe549ad3d6a52924a73181b45791e76120b975138fac9ec9b75db9f3';\nexport const T2000_CONFIG_ID = process.env.T2000_CONFIG_ID ?? '0x408add9aa9322f93cfd87523d8f603006eb8713894f4c460283c58a6888dae8a';\nexport const T2000_ADMIN_CAP_ID = '0x863d1b02cba1b93d0fe9b87eb92d58b60c1e85c001022cb2a760e07bade47e65';\nexport const T2000_UPGRADE_CAP_ID = '0xef28746d40f43ca6be1352102cef0152133bf5594e69caab28f40b1de74490c1';\nexport const T2000_TREASURY_ID = process.env.T2000_TREASURY_ID ?? '0x3bb501b8300125dca59019247941a42af6b292a150ce3cfcce9449456be2ec91';\n\nexport const DEFAULT_NETWORK = 'mainnet' as const;\nexport const DEFAULT_RPC_URL = 'https://fullnode.mainnet.sui.io:443';\nexport const DEFAULT_KEY_PATH = '~/.t2000/wallet.key';\nexport const DEFAULT_CONFIG_PATH = '~/.t2000/config.json';\n\nexport const API_BASE_URL = process.env.T2000_API_URL ?? 'https://api.t2000.ai';\n\nexport const CETUS_USDC_SUI_POOL = '0x51e883ba7c0b566a26cbc8a94cd33eb0abd418a77cc1e60ad22fd9b1f29cd2ab';\nexport const CETUS_GLOBAL_CONFIG = '0xdaa46292632c3c4d8f31f23ea0f9b36a28ff3677e9684980e4438403a67a3d8f';\nexport const CETUS_PACKAGE = '0x1eabed72c53feb3805120a081dc15963c204dc8d091542592abaf7a35689b2fb';\n\nexport const SENTINEL = {\n PACKAGE: '0x88b83f36dafcd5f6dcdcf1d2cb5889b03f61264ab3cee9cae35db7aa940a21b7',\n AGENT_REGISTRY: '0xc47564f5f14c12b31e0dfa1a3dc99a6380a1edf8929c28cb0eaa3359c8db36ac',\n ENCLAVE: '0xfb1261aeb9583514cb1341a548a5ec12d1231bd96af22215f1792617a93e1213',\n PROTOCOL_CONFIG: '0x2fa4fa4a1dd0498612304635ff9334e1b922e78af325000e9d9c0e88adea459f',\n TEE_API: 'https://app.suisentinel.xyz/api/consume-prompt',\n SENTINELS_API: 'https://api.suisentinel.xyz/agents/mainnet',\n RANDOM: '0x8',\n MIN_FEE_MIST: 100_000_000n, // 0.1 SUI\n MAX_PROMPT_TOKENS: 600,\n} as const;\n","export type T2000ErrorCode =\n | 'INSUFFICIENT_BALANCE'\n | 'INSUFFICIENT_GAS'\n | 'INVALID_ADDRESS'\n | 'INVALID_AMOUNT'\n | 'WALLET_NOT_FOUND'\n | 'WALLET_LOCKED'\n | 'WALLET_EXISTS'\n | 'SPONSOR_FAILED'\n | 'SPONSOR_RATE_LIMITED'\n | 'GAS_STATION_UNAVAILABLE'\n | 'GAS_FEE_EXCEEDED'\n | 'SIMULATION_FAILED'\n | 'TRANSACTION_FAILED'\n | 'ASSET_NOT_SUPPORTED'\n | 'SLIPPAGE_EXCEEDED'\n | 'HEALTH_FACTOR_TOO_LOW'\n | 'WITHDRAW_WOULD_LIQUIDATE'\n | 'NO_COLLATERAL'\n | 'PROTOCOL_PAUSED'\n | 'PROTOCOL_UNAVAILABLE'\n | 'RPC_ERROR'\n | 'RPC_UNREACHABLE'\n | 'SPONSOR_UNAVAILABLE'\n | 'AUTO_TOPUP_FAILED'\n | 'PRICE_EXCEEDS_LIMIT'\n | 'UNSUPPORTED_NETWORK'\n | 'PAYMENT_EXPIRED'\n | 'DUPLICATE_PAYMENT'\n | 'FACILITATOR_REJECTION'\n | 'FACILITATOR_TIMEOUT'\n | 'SENTINEL_API_ERROR'\n | 'SENTINEL_NOT_FOUND'\n | 'SENTINEL_TX_FAILED'\n | 'SENTINEL_TEE_ERROR'\n | 'UNKNOWN';\n\nexport interface T2000ErrorData {\n reason?: string;\n [key: string]: unknown;\n}\n\nexport class T2000Error extends Error {\n readonly code: T2000ErrorCode;\n readonly data?: T2000ErrorData;\n readonly retryable: boolean;\n\n constructor(code: T2000ErrorCode, message: string, data?: T2000ErrorData, retryable = false) {\n super(message);\n this.name = 'T2000Error';\n this.code = code;\n this.data = data;\n this.retryable = retryable;\n }\n\n toJSON() {\n return {\n error: this.code,\n message: this.message,\n ...(this.data && { data: this.data }),\n retryable: this.retryable,\n };\n }\n}\n\nexport function mapWalletError(error: unknown): T2000Error {\n const msg = error instanceof Error ? error.message : String(error);\n\n if (msg.includes('rejected') || msg.includes('cancelled')) {\n return new T2000Error('TRANSACTION_FAILED', 'Transaction cancelled');\n }\n if (msg.includes('Insufficient') || msg.includes('insufficient')) {\n return new T2000Error('INSUFFICIENT_BALANCE', 'Insufficient balance');\n }\n\n return new T2000Error('UNKNOWN', msg, undefined, true);\n}\n\nexport function mapMoveAbortCode(code: number): string {\n const abortMessages: Record<number, string> = {\n 1: 'Protocol is temporarily paused',\n 2: 'Amount must be greater than zero',\n 3: 'Invalid operation type',\n 4: 'Fee rate exceeds maximum',\n 5: 'Insufficient treasury balance',\n 6: 'Not authorized',\n 7: 'Package version mismatch — upgrade required',\n 8: 'Timelock is active — wait for expiry',\n 9: 'No pending change to execute',\n 10: 'Already at current version',\n };\n return abortMessages[code] ?? `Move abort code: ${code}`;\n}\n","import { SuiJsonRpcClient, getJsonRpcFullnodeUrl } from '@mysten/sui/jsonRpc';\nimport { isValidSuiAddress, normalizeSuiAddress } from '@mysten/sui/utils';\nimport { DEFAULT_RPC_URL } from '../constants.js';\nimport { T2000Error } from '../errors.js';\n\nlet cachedClient: SuiJsonRpcClient | null = null;\n\nexport function getSuiClient(rpcUrl?: string): SuiJsonRpcClient {\n const url = rpcUrl ?? DEFAULT_RPC_URL;\n if (cachedClient) return cachedClient;\n cachedClient = new SuiJsonRpcClient({ url, network: 'mainnet' });\n return cachedClient;\n}\n\nexport function createSuiClient(network: 'mainnet' | 'testnet' = 'mainnet'): SuiJsonRpcClient {\n return new SuiJsonRpcClient({ url: getJsonRpcFullnodeUrl(network), network });\n}\n\nexport function validateAddress(address: string): string {\n const normalized = normalizeSuiAddress(address);\n if (!isValidSuiAddress(normalized)) {\n throw new T2000Error('INVALID_ADDRESS', `Invalid Sui address: ${address}`);\n }\n return normalized;\n}\n\nexport function truncateAddress(address: string): string {\n if (address.length <= 10) return address;\n return `${address.slice(0, 6)}...${address.slice(-4)}`;\n}\n","import { Ed25519Keypair } from '@mysten/sui/keypairs/ed25519';\nimport { decodeSuiPrivateKey } from '@mysten/sui/cryptography';\nimport { randomBytes, createCipheriv, createDecipheriv, scryptSync } from 'node:crypto';\nimport { readFile, writeFile, mkdir, access } from 'node:fs/promises';\nimport { dirname, resolve } from 'node:path';\nimport { homedir } from 'node:os';\nimport { T2000Error } from '../errors.js';\nimport { DEFAULT_KEY_PATH } from '../constants.js';\n\nconst ALGORITHM = 'aes-256-gcm';\nconst SCRYPT_N = 2 ** 14; // 16384 — secure and fast enough\nconst SCRYPT_R = 8;\nconst SCRYPT_P = 1;\nconst SALT_LENGTH = 32;\nconst IV_LENGTH = 16;\nconst TAG_LENGTH = 16;\n\ninterface EncryptedKey {\n version: 1;\n algorithm: typeof ALGORITHM;\n salt: string;\n iv: string;\n tag: string;\n ciphertext: string;\n}\n\nfunction expandPath(p: string): string {\n if (p.startsWith('~')) return resolve(homedir(), p.slice(2));\n return resolve(p);\n}\n\nfunction deriveKey(passphrase: string, salt: Buffer): Buffer {\n return scryptSync(passphrase, salt, 32, { N: SCRYPT_N, r: SCRYPT_R, p: SCRYPT_P });\n}\n\nfunction encrypt(data: Buffer, passphrase: string): EncryptedKey {\n const salt = randomBytes(SALT_LENGTH);\n const key = deriveKey(passphrase, salt);\n const iv = randomBytes(IV_LENGTH);\n\n const cipher = createCipheriv(ALGORITHM, key, iv);\n const ciphertext = Buffer.concat([cipher.update(data), cipher.final()]);\n const tag = cipher.getAuthTag();\n\n return {\n version: 1,\n algorithm: ALGORITHM,\n salt: salt.toString('hex'),\n iv: iv.toString('hex'),\n tag: tag.toString('hex'),\n ciphertext: ciphertext.toString('hex'),\n };\n}\n\nfunction decrypt(encrypted: EncryptedKey, passphrase: string): Buffer {\n const salt = Buffer.from(encrypted.salt, 'hex');\n const key = deriveKey(passphrase, salt);\n const iv = Buffer.from(encrypted.iv, 'hex');\n const tag = Buffer.from(encrypted.tag, 'hex');\n const ciphertext = Buffer.from(encrypted.ciphertext, 'hex');\n\n const decipher = createDecipheriv(ALGORITHM, key, iv);\n decipher.setAuthTag(tag);\n\n try {\n return Buffer.concat([decipher.update(ciphertext), decipher.final()]);\n } catch {\n throw new T2000Error('WALLET_LOCKED', 'Invalid PIN');\n }\n}\n\nexport function generateKeypair(): Ed25519Keypair {\n return Ed25519Keypair.generate();\n}\n\nexport function keypairFromPrivateKey(privateKey: string): Ed25519Keypair {\n if (privateKey.startsWith('suiprivkey')) {\n const decoded = decodeSuiPrivateKey(privateKey);\n return Ed25519Keypair.fromSecretKey(decoded.secretKey);\n }\n const bytes = Buffer.from(privateKey.replace(/^0x/, ''), 'hex');\n return Ed25519Keypair.fromSecretKey(bytes);\n}\n\nexport async function saveKey(\n keypair: Ed25519Keypair,\n passphrase: string,\n keyPath?: string,\n): Promise<string> {\n const filePath = expandPath(keyPath ?? DEFAULT_KEY_PATH);\n\n try {\n await access(filePath);\n throw new T2000Error('WALLET_EXISTS', `Wallet already exists at ${filePath}`);\n } catch (error) {\n if (error instanceof T2000Error) throw error;\n }\n\n await mkdir(dirname(filePath), { recursive: true });\n\n const bech32Key = keypair.getSecretKey();\n const encrypted = encrypt(Buffer.from(bech32Key, 'utf-8'), passphrase);\n\n await writeFile(filePath, JSON.stringify(encrypted, null, 2), { mode: 0o600 });\n\n return filePath;\n}\n\nexport async function loadKey(passphrase: string, keyPath?: string): Promise<Ed25519Keypair> {\n const filePath = expandPath(keyPath ?? DEFAULT_KEY_PATH);\n\n let content: string;\n try {\n content = await readFile(filePath, 'utf-8');\n } catch {\n throw new T2000Error('WALLET_NOT_FOUND', `No wallet found at ${filePath}`);\n }\n\n const encrypted: EncryptedKey = JSON.parse(content);\n const decrypted = decrypt(encrypted, passphrase);\n const bech32Key = decrypted.toString('utf-8');\n const decoded = decodeSuiPrivateKey(bech32Key);\n\n return Ed25519Keypair.fromSecretKey(decoded.secretKey);\n}\n\nexport async function walletExists(keyPath?: string): Promise<boolean> {\n const filePath = expandPath(keyPath ?? DEFAULT_KEY_PATH);\n try {\n await access(filePath);\n return true;\n } catch {\n return false;\n }\n}\n\nexport function exportPrivateKey(keypair: Ed25519Keypair): string {\n return keypair.getSecretKey();\n}\n\nexport function getAddress(keypair: Ed25519Keypair): string {\n return keypair.getPublicKey().toSuiAddress();\n}\n","import { MIST_PER_SUI, BPS_DENOMINATOR, USDC_DECIMALS, SUI_DECIMALS } from '../constants.js';\n\nexport function mistToSui(mist: bigint): number {\n return Number(mist) / Number(MIST_PER_SUI);\n}\n\nexport function suiToMist(sui: number): bigint {\n return BigInt(Math.round(sui * Number(MIST_PER_SUI)));\n}\n\nexport function usdcToRaw(amount: number): bigint {\n return BigInt(Math.round(amount * 10 ** USDC_DECIMALS));\n}\n\nexport function rawToUsdc(raw: bigint): number {\n return Number(raw) / 10 ** USDC_DECIMALS;\n}\n\nexport function rawToDisplay(raw: bigint, decimals: number): number {\n return Number(raw) / 10 ** decimals;\n}\n\nexport function displayToRaw(amount: number, decimals: number): bigint {\n return BigInt(Math.round(amount * 10 ** decimals));\n}\n\nexport function bpsToPercent(bps: bigint): number {\n return Number(bps) / Number(BPS_DENOMINATOR) * 100;\n}\n\nexport function formatUsd(amount: number): string {\n return `$${amount.toFixed(2)}`;\n}\n\nexport function formatSui(amount: number): string {\n if (amount < 0.001) return `${amount.toFixed(6)} SUI`;\n return `${amount.toFixed(3)} SUI`;\n}\n\nexport function formatLargeNumber(n: number): string {\n if (n >= 1_000_000) return `${(n / 1_000_000).toFixed(1)}M`;\n if (n >= 1_000) return `${(n / 1_000).toFixed(1)}K`;\n return n.toFixed(2);\n}\n","import { Transaction } from '@mysten/sui/transactions';\nimport type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type { Ed25519Keypair } from '@mysten/sui/keypairs/ed25519';\nimport { SUPPORTED_ASSETS, type SupportedAsset } from '../constants.js';\nimport { T2000Error } from '../errors.js';\nimport { validateAddress } from '../utils/sui.js';\nimport { displayToRaw } from '../utils/format.js';\n\nexport interface SendParams {\n client: SuiJsonRpcClient;\n keypair: Ed25519Keypair;\n to: string;\n amount: number;\n asset?: SupportedAsset;\n}\n\nexport interface SendTxResult {\n digest: string;\n gasCost: number;\n}\n\nexport async function buildSendTx({\n client,\n address,\n to,\n amount,\n asset = 'USDC',\n}: { client: SuiJsonRpcClient; address: string; to: string; amount: number; asset?: SupportedAsset }): Promise<Transaction> {\n const recipient = validateAddress(to);\n const assetInfo = SUPPORTED_ASSETS[asset];\n\n if (!assetInfo) throw new T2000Error('ASSET_NOT_SUPPORTED', `Asset ${asset} is not supported`);\n if (amount <= 0) throw new T2000Error('INVALID_AMOUNT', 'Amount must be greater than zero');\n\n const rawAmount = displayToRaw(amount, assetInfo.decimals);\n const tx = new Transaction();\n tx.setSender(address);\n\n if (asset === 'SUI') {\n const [coin] = tx.splitCoins(tx.gas, [rawAmount]);\n tx.transferObjects([coin], recipient);\n } else {\n const coins = await client.getCoins({ owner: address, coinType: assetInfo.type });\n if (coins.data.length === 0) throw new T2000Error('INSUFFICIENT_BALANCE', `No ${asset} coins found`);\n\n const totalBalance = coins.data.reduce((sum, c) => sum + BigInt(c.balance), 0n);\n if (totalBalance < rawAmount) {\n throw new T2000Error('INSUFFICIENT_BALANCE', `Insufficient ${asset} balance`, {\n available: Number(totalBalance) / 10 ** assetInfo.decimals, required: amount,\n });\n }\n\n const primaryCoin = tx.object(coins.data[0].coinObjectId);\n if (coins.data.length > 1) {\n tx.mergeCoins(primaryCoin, coins.data.slice(1).map((c) => tx.object(c.coinObjectId)));\n }\n const [sendCoin] = tx.splitCoins(primaryCoin, [rawAmount]);\n tx.transferObjects([sendCoin], recipient);\n }\n\n return tx;\n}\n\nexport async function buildAndExecuteSend({\n client,\n keypair,\n to,\n amount,\n asset = 'USDC',\n}: SendParams): Promise<SendTxResult> {\n const recipient = validateAddress(to);\n const assetInfo = SUPPORTED_ASSETS[asset];\n\n if (!assetInfo) {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `Asset ${asset} is not supported`);\n }\n if (amount <= 0) {\n throw new T2000Error('INVALID_AMOUNT', 'Amount must be greater than zero');\n }\n\n const senderAddress = keypair.getPublicKey().toSuiAddress();\n const rawAmount = displayToRaw(amount, assetInfo.decimals);\n\n const tx = new Transaction();\n\n if (asset === 'SUI') {\n const [coin] = tx.splitCoins(tx.gas, [rawAmount]);\n tx.transferObjects([coin], recipient);\n } else {\n const coins = await client.getCoins({\n owner: senderAddress,\n coinType: assetInfo.type,\n });\n\n if (coins.data.length === 0) {\n throw new T2000Error('INSUFFICIENT_BALANCE', `No ${asset} coins found`);\n }\n\n const totalBalance = coins.data.reduce(\n (sum, c) => sum + BigInt(c.balance),\n 0n,\n );\n\n if (totalBalance < rawAmount) {\n throw new T2000Error('INSUFFICIENT_BALANCE', `Insufficient ${asset} balance`, {\n available: Number(totalBalance) / 10 ** assetInfo.decimals,\n required: amount,\n });\n }\n\n const primaryCoin = tx.object(coins.data[0].coinObjectId);\n\n if (coins.data.length > 1) {\n tx.mergeCoins(\n primaryCoin,\n coins.data.slice(1).map((c) => tx.object(c.coinObjectId)),\n );\n }\n\n const [sendCoin] = tx.splitCoins(primaryCoin, [rawAmount]);\n tx.transferObjects([sendCoin], recipient);\n }\n\n const result = await client.signAndExecuteTransaction({\n signer: keypair,\n transaction: tx,\n options: { showEffects: true },\n });\n\n await client.waitForTransaction({ digest: result.digest });\n\n const gasUsed = result.effects?.gasUsed;\n const gasCost = gasUsed\n ? Math.abs(\n (Number(gasUsed.computationCost) +\n Number(gasUsed.storageCost) -\n Number(gasUsed.storageRebate)) /\n 1e9\n )\n : 0;\n\n return {\n digest: result.digest,\n gasCost,\n };\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport { SUPPORTED_ASSETS, MIST_PER_SUI, CETUS_USDC_SUI_POOL } from '../constants.js';\nimport type { BalanceResponse } from '../types.js';\n\nlet _cachedSuiPrice = 0;\nlet _priceLastFetched = 0;\nconst PRICE_CACHE_TTL_MS = 60_000;\n\n/**\n * Fetch SUI price in USD from the Cetus USDC/SUI pool's sqrt_price.\n *\n * Pool is Pool<USDC, SUI> so coin_a = USDC (6 dec), coin_b = SUI (9 dec).\n * current_sqrt_price (Q64 fixed-point) encodes sqrt(raw_price) where\n * raw_price = SUI_raw / USDC_raw.\n *\n * USDC per SUI = 10^(decimals_a - decimals_b) / raw_price\n * = 10^(6-9) / raw_price\n * = 1 / (raw_price * 1000)\n *\n * Equivalently: 1000 / raw_price\n */\nasync function fetchSuiPrice(client: SuiJsonRpcClient): Promise<number> {\n const now = Date.now();\n if (_cachedSuiPrice > 0 && now - _priceLastFetched < PRICE_CACHE_TTL_MS) {\n return _cachedSuiPrice;\n }\n\n try {\n const pool = await client.getObject({\n id: CETUS_USDC_SUI_POOL,\n options: { showContent: true },\n });\n\n if (pool.data?.content?.dataType === 'moveObject') {\n const fields = pool.data.content.fields as Record<string, unknown>;\n const currentSqrtPrice = BigInt(String(fields.current_sqrt_price ?? '0'));\n\n if (currentSqrtPrice > 0n) {\n const Q64 = 2n ** 64n;\n const sqrtPriceFloat = Number(currentSqrtPrice) / Number(Q64);\n const rawPrice = sqrtPriceFloat * sqrtPriceFloat;\n const price = 1000 / rawPrice;\n if (price > 0.01 && price < 1000) {\n _cachedSuiPrice = price;\n _priceLastFetched = now;\n }\n }\n }\n } catch {\n // Use cached/fallback price\n }\n\n return _cachedSuiPrice;\n}\n\nexport async function queryBalance(\n client: SuiJsonRpcClient,\n address: string,\n): Promise<BalanceResponse> {\n const [usdcBalance, suiBalance, suiPriceUsd] = await Promise.all([\n client.getBalance({ owner: address, coinType: SUPPORTED_ASSETS.USDC.type }),\n client.getBalance({ owner: address, coinType: SUPPORTED_ASSETS.SUI.type }),\n fetchSuiPrice(client),\n ]);\n\n const usdcAmount = Number(usdcBalance.totalBalance) / 10 ** SUPPORTED_ASSETS.USDC.decimals;\n const suiAmount = Number(suiBalance.totalBalance) / Number(MIST_PER_SUI);\n\n const savings = 0; // Merged from NAVI in T2000.balance()\n const usdEquiv = suiAmount * suiPriceUsd;\n const total = usdcAmount + savings + usdEquiv;\n\n return {\n available: usdcAmount,\n savings,\n gasReserve: {\n sui: suiAmount,\n usdEquiv,\n },\n total,\n assets: {\n USDC: usdcAmount,\n SUI: suiAmount,\n },\n };\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type { TransactionRecord } from '../types.js';\n\nexport async function queryHistory(\n client: SuiJsonRpcClient,\n address: string,\n limit = 20,\n): Promise<TransactionRecord[]> {\n const txns = await client.queryTransactionBlocks({\n filter: { FromAddress: address },\n options: { showEffects: true, showInput: true },\n limit,\n order: 'descending',\n });\n\n return txns.data.map((tx) => {\n const gasUsed = tx.effects?.gasUsed;\n const gasCost = gasUsed\n ? (Number(gasUsed.computationCost) +\n Number(gasUsed.storageCost) -\n Number(gasUsed.storageRebate)) /\n 1e9\n : undefined;\n\n return {\n digest: tx.digest,\n action: inferAction(tx.transaction),\n timestamp: Number(tx.timestampMs ?? 0),\n gasCost,\n };\n });\n}\n\nfunction inferAction(txBlock: unknown): string {\n if (!txBlock || typeof txBlock !== 'object') return 'unknown';\n const data = 'data' in txBlock ? (txBlock as { data?: unknown }).data : undefined;\n if (!data || typeof data !== 'object') return 'unknown';\n const inner = 'transaction' in data ? (data as { transaction?: unknown }).transaction : undefined;\n if (!inner || typeof inner !== 'object') return 'unknown';\n\n const kind = 'kind' in inner ? (inner as { kind: string }).kind : undefined;\n if (kind === 'ProgrammableTransaction') return 'transaction';\n return kind ?? 'unknown';\n}\n","import { Transaction, type TransactionObjectArgument } from '@mysten/sui/transactions';\nimport type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport {\n SAVE_FEE_BPS,\n SWAP_FEE_BPS,\n BORROW_FEE_BPS,\n BPS_DENOMINATOR,\n SUPPORTED_ASSETS,\n T2000_PACKAGE_ID,\n T2000_TREASURY_ID,\n T2000_CONFIG_ID,\n API_BASE_URL,\n} from '../constants.js';\nimport { usdcToRaw } from '../utils/format.js';\n\nexport type FeeOperation = 'save' | 'swap' | 'borrow';\n\nexport interface ProtocolFeeInfo {\n amount: number;\n asset: string;\n rate: number;\n rawAmount: bigint;\n}\n\nconst FEE_RATES: Record<FeeOperation, bigint> = {\n save: SAVE_FEE_BPS,\n swap: SWAP_FEE_BPS,\n borrow: BORROW_FEE_BPS,\n};\n\nconst OP_CODES: Record<FeeOperation, number> = {\n save: 0,\n swap: 1,\n borrow: 2,\n};\n\nexport function calculateFee(operation: FeeOperation, amount: number): ProtocolFeeInfo {\n const bps = FEE_RATES[operation];\n const feeAmount = amount * Number(bps) / Number(BPS_DENOMINATOR);\n const rawAmount = usdcToRaw(feeAmount);\n\n return {\n amount: feeAmount,\n asset: 'USDC',\n rate: Number(bps) / Number(BPS_DENOMINATOR),\n rawAmount,\n };\n}\n\n/**\n * Add on-chain fee collection to an existing PTB via t2000::treasury::collect_fee().\n * The Move function splits the fee from the payment coin and stores it in the\n * Treasury's internal Balance<T>. Atomic — reverts with the operation if it fails.\n */\nexport function addCollectFeeToTx(\n tx: Transaction,\n paymentCoin: TransactionObjectArgument,\n operation: FeeOperation,\n): void {\n const bps = FEE_RATES[operation];\n if (bps <= 0n) return;\n\n tx.moveCall({\n target: `${T2000_PACKAGE_ID}::treasury::collect_fee`,\n typeArguments: [SUPPORTED_ASSETS.USDC.type],\n arguments: [\n tx.object(T2000_TREASURY_ID),\n tx.object(T2000_CONFIG_ID),\n paymentCoin,\n tx.pure.u8(OP_CODES[operation]),\n ],\n });\n}\n\nexport async function reportFee(\n agentAddress: string,\n operation: string,\n feeAmount: number,\n feeRate: number,\n txDigest: string,\n): Promise<void> {\n try {\n await fetch(`${API_BASE_URL}/api/fees`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({\n agentAddress,\n operation,\n feeAmount: feeAmount.toString(),\n feeRate: feeRate.toString(),\n txDigest,\n }),\n });\n } catch {\n // Non-critical — best-effort reporting\n }\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type { Ed25519Keypair } from '@mysten/sui/keypairs/ed25519';\nimport { Transaction, type TransactionObjectArgument } from '@mysten/sui/transactions';\nimport { bcs } from '@mysten/sui/bcs';\nimport { SUPPORTED_ASSETS } from '../constants.js';\nimport { T2000Error } from '../errors.js';\nimport { usdcToRaw } from '../utils/format.js';\nimport { addCollectFeeToTx } from './protocolFee.js';\nimport type {\n SaveResult,\n WithdrawResult,\n BorrowResult,\n RepayResult,\n GasMethod,\n RatesResult,\n PositionsResult,\n PositionEntry,\n HealthFactorResult,\n MaxWithdrawResult,\n MaxBorrowResult,\n} from '../types.js';\n\nconst USDC_TYPE = SUPPORTED_ASSETS.USDC.type;\nconst RATE_DECIMALS = 27;\nconst LTV_DECIMALS = 27;\nconst MIN_HEALTH_FACTOR = 1.5;\nconst WITHDRAW_DUST_BUFFER = 0.001;\nconst CLOCK = '0x06';\nconst SUI_SYSTEM_STATE = '0x05';\nconst NAVI_BALANCE_DECIMALS = 9;\nconst CONFIG_API = 'https://open-api.naviprotocol.io/api/navi/config?env=prod';\nconst POOLS_API = 'https://open-api.naviprotocol.io/api/navi/pools?env=prod';\n\nconst PACKAGE_API = 'https://open-api.naviprotocol.io/api/package';\nlet packageCache: { id: string; ts: number } | null = null;\n\n// ---------------------------------------------------------------------------\n// Types\n// ---------------------------------------------------------------------------\n\ninterface OracleFeed {\n oracleId: number;\n assetId: number;\n feedId: string;\n pythPriceInfoObject: string;\n}\n\ninterface NaviConfig {\n package: string;\n storage: string;\n incentiveV2: string;\n incentiveV3: string;\n uiGetter: string;\n oracle: {\n packageId: string;\n priceOracle: string;\n oracleConfig: string;\n supraOracleHolder: string;\n switchboardAggregator: string;\n feeds: OracleFeed[];\n };\n}\n\n// Oracle package ID comes from config.oracle.packageId (not hardcoded)\n\ninterface NaviPool {\n id: number;\n coinType: string;\n suiCoinType: string;\n currentSupplyRate: string;\n currentBorrowRate: string;\n currentSupplyIndex: string;\n currentBorrowIndex: string;\n ltv: string;\n liquidationFactor: { bonus: string; ratio: string; threshold: string };\n contract: { reserveId: string; pool: string };\n token: { symbol: string; decimals: number; price: number };\n}\n\ninterface UserState {\n assetId: number;\n supplyBalance: bigint;\n borrowBalance: bigint;\n}\n\nfunction toBigInt(v: unknown): bigint {\n if (typeof v === 'bigint') return v;\n return BigInt(String(v));\n}\n\n// ---------------------------------------------------------------------------\n// BCS\n// ---------------------------------------------------------------------------\n\nconst UserStateInfo = bcs.struct('UserStateInfo', {\n asset_id: bcs.u8(),\n borrow_balance: bcs.u256(),\n supply_balance: bcs.u256(),\n});\n\nfunction decodeDevInspect<T>(\n result: { results?: Array<{ returnValues?: Array<[number[], string]> }> | null; error?: string | null },\n schema: { parse: (data: Uint8Array) => T },\n): T | undefined {\n const rv = result.results?.[0]?.returnValues?.[0];\n if (result.error || !rv) return undefined;\n const bytes = Uint8Array.from(rv[0]);\n return schema.parse(bytes);\n}\n\n// ---------------------------------------------------------------------------\n// Config + Pool cache\n// ---------------------------------------------------------------------------\n\nlet configCache: { data: NaviConfig; ts: number } | null = null;\nlet poolsCache: { data: NaviPool[]; ts: number } | null = null;\nconst CACHE_TTL = 5 * 60_000;\n\nasync function fetchJson<T>(url: string): Promise<T> {\n const res = await fetch(url);\n if (!res.ok) throw new T2000Error('PROTOCOL_UNAVAILABLE', `NAVI API error: ${res.status}`);\n const json = (await res.json()) as { data?: T; code?: number };\n return (json.data ?? json) as T;\n}\n\nasync function getLatestPackageId(): Promise<string> {\n if (packageCache && Date.now() - packageCache.ts < CACHE_TTL) return packageCache.id;\n const res = await fetch(PACKAGE_API);\n if (!res.ok) throw new T2000Error('PROTOCOL_UNAVAILABLE', `NAVI package API error: ${res.status}`);\n const json = (await res.json()) as { packageId?: string };\n if (!json.packageId) throw new T2000Error('PROTOCOL_UNAVAILABLE', 'NAVI package API returned no packageId');\n packageCache = { id: json.packageId, ts: Date.now() };\n return json.packageId;\n}\n\nasync function getConfig(fresh = false): Promise<NaviConfig> {\n if (configCache && !fresh && Date.now() - configCache.ts < CACHE_TTL) return configCache.data;\n const [data, latestPkg] = await Promise.all([\n fetchJson<NaviConfig>(CONFIG_API),\n getLatestPackageId(),\n ]);\n data.package = latestPkg;\n configCache = { data, ts: Date.now() };\n return data;\n}\n\nasync function getPools(fresh = false): Promise<NaviPool[]> {\n if (poolsCache && !fresh && Date.now() - poolsCache.ts < CACHE_TTL) return poolsCache.data;\n const data = await fetchJson<NaviPool[]>(POOLS_API);\n poolsCache = { data, ts: Date.now() };\n return data;\n}\n\nasync function getUsdcPool(): Promise<NaviPool> {\n const pools = await getPools();\n const usdc = pools.find(\n (p) => p.token?.symbol === 'USDC' || p.coinType?.toLowerCase().includes('usdc'),\n );\n if (!usdc) throw new T2000Error('PROTOCOL_UNAVAILABLE', 'USDC pool not found on NAVI');\n return usdc;\n}\n\n// ---------------------------------------------------------------------------\n// Oracle price update (required before withdraw/borrow)\n// ---------------------------------------------------------------------------\n\nfunction addOracleUpdate(tx: Transaction, config: NaviConfig, pool: NaviPool): void {\n const feed = config.oracle.feeds?.find((f) => f.assetId === pool.id);\n if (!feed) {\n throw new T2000Error('PROTOCOL_UNAVAILABLE', `Oracle feed not found for asset ${pool.token?.symbol ?? pool.id}`);\n }\n\n tx.moveCall({\n target: `${config.oracle.packageId}::oracle_pro::update_single_price_v2`,\n arguments: [\n tx.object(CLOCK),\n tx.object(config.oracle.oracleConfig),\n tx.object(config.oracle.priceOracle),\n tx.object(config.oracle.supraOracleHolder),\n tx.object(feed.pythPriceInfoObject),\n tx.object(config.oracle.switchboardAggregator),\n tx.pure.address(feed.feedId),\n ],\n });\n}\n\n// ---------------------------------------------------------------------------\n// Helpers\n// ---------------------------------------------------------------------------\n\nfunction extractGasCost(effects: { gasUsed?: { computationCost: string; storageCost: string; storageRebate: string } } | undefined | null): number {\n if (!effects?.gasUsed) return 0;\n return Math.abs(\n (Number(effects.gasUsed.computationCost) +\n Number(effects.gasUsed.storageCost) -\n Number(effects.gasUsed.storageRebate)) / 1e9,\n );\n}\n\nfunction rateToApy(rawRate: string): number {\n if (!rawRate || rawRate === '0') return 0;\n return Number(BigInt(rawRate)) / 10 ** RATE_DECIMALS * 100;\n}\n\nfunction parseLtv(rawLtv: string): number {\n if (!rawLtv || rawLtv === '0') return 0.75;\n return Number(BigInt(rawLtv)) / 10 ** LTV_DECIMALS;\n}\n\nfunction parseLiqThreshold(val: string | number): number {\n if (typeof val === 'number') return val;\n const n = Number(val);\n if (n > 1) return Number(BigInt(val)) / 10 ** LTV_DECIMALS;\n return n;\n}\n\nfunction normalizeHealthFactor(raw: number): number {\n const v = raw / 10 ** RATE_DECIMALS;\n return v > 1e5 ? Infinity : v;\n}\n\nfunction compoundBalance(rawBalance: bigint, currentIndex: string): number {\n if (!rawBalance || !currentIndex || currentIndex === '0') return 0;\n const scale = BigInt('1' + '0'.repeat(RATE_DECIMALS));\n const half = scale / 2n;\n const result = (rawBalance * BigInt(currentIndex) + half) / scale;\n return Number(result) / 10 ** NAVI_BALANCE_DECIMALS;\n}\n\n// ---------------------------------------------------------------------------\n// On-chain reads\n// ---------------------------------------------------------------------------\n\nasync function getUserState(client: SuiJsonRpcClient, address: string): Promise<UserState[]> {\n const config = await getConfig();\n const tx = new Transaction();\n tx.moveCall({\n target: `${config.uiGetter}::getter_unchecked::get_user_state`,\n arguments: [tx.object(config.storage), tx.pure.address(address)],\n });\n\n const result = await client.devInspectTransactionBlock({\n transactionBlock: tx,\n sender: address,\n });\n\n const decoded = decodeDevInspect(result, bcs.vector(UserStateInfo));\n if (!decoded) return [];\n\n return (decoded as Array<{ asset_id: number; supply_balance: unknown; borrow_balance: unknown }>)\n .map((s) => ({\n assetId: s.asset_id,\n supplyBalance: toBigInt(s.supply_balance),\n borrowBalance: toBigInt(s.borrow_balance),\n }))\n .filter((s) => s.supplyBalance !== 0n || s.borrowBalance !== 0n);\n}\n\nasync function fetchCoins(\n client: SuiJsonRpcClient,\n owner: string,\n coinType: string,\n): Promise<Array<{ coinObjectId: string; balance: string }>> {\n const all: Array<{ coinObjectId: string; balance: string }> = [];\n let cursor: string | null | undefined;\n let hasNext = true;\n\n while (hasNext) {\n const page = await client.getCoins({ owner, coinType, cursor: cursor ?? undefined });\n all.push(...page.data.map((c) => ({ coinObjectId: c.coinObjectId, balance: c.balance })));\n cursor = page.nextCursor;\n hasNext = page.hasNextPage;\n }\n\n return all;\n}\n\nfunction mergeCoins(\n tx: Transaction,\n coins: Array<{ coinObjectId: string; balance: string }>,\n): TransactionObjectArgument {\n if (coins.length === 0) throw new T2000Error('INSUFFICIENT_BALANCE', 'No coins to merge');\n\n const primary = tx.object(coins[0].coinObjectId);\n if (coins.length > 1) {\n tx.mergeCoins(primary, coins.slice(1).map((c) => tx.object(c.coinObjectId)));\n }\n\n return primary;\n}\n\n// ---------------------------------------------------------------------------\n// Public API\n// ---------------------------------------------------------------------------\n\nexport async function buildSaveTx(\n client: SuiJsonRpcClient,\n address: string,\n amount: number,\n options: { collectFee?: boolean } = {},\n): Promise<Transaction> {\n if (!amount || amount <= 0 || !Number.isFinite(amount)) {\n throw new T2000Error('INVALID_AMOUNT', 'Save amount must be a positive number');\n }\n const rawAmount = Number(usdcToRaw(amount));\n const [config, pool] = await Promise.all([getConfig(), getUsdcPool()]);\n\n const coins = await fetchCoins(client, address, USDC_TYPE);\n if (coins.length === 0) throw new T2000Error('INSUFFICIENT_BALANCE', 'No USDC coins found');\n\n const tx = new Transaction();\n tx.setSender(address);\n\n const coinObj = mergeCoins(tx, coins);\n\n if (options.collectFee) {\n addCollectFeeToTx(tx, coinObj, 'save');\n }\n\n tx.moveCall({\n target: `${config.package}::incentive_v3::entry_deposit`,\n arguments: [\n tx.object(CLOCK),\n tx.object(config.storage),\n tx.object(pool.contract.pool),\n tx.pure.u8(pool.id),\n coinObj,\n tx.pure.u64(rawAmount),\n tx.object(config.incentiveV2),\n tx.object(config.incentiveV3),\n ],\n typeArguments: [pool.suiCoinType],\n });\n\n return tx;\n}\n\nexport async function save(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n amount: number,\n): Promise<SaveResult> {\n const address = keypair.getPublicKey().toSuiAddress();\n const tx = await buildSaveTx(client, address, amount);\n\n const result = await client.signAndExecuteTransaction({\n signer: keypair,\n transaction: tx,\n options: { showEffects: true },\n });\n await client.waitForTransaction({ digest: result.digest });\n\n const rates = await getRates(client);\n\n return {\n success: true,\n tx: result.digest,\n amount,\n apy: rates.USDC.saveApy,\n fee: 0,\n gasCost: extractGasCost(result.effects),\n gasMethod: 'self-funded' as GasMethod,\n savingsBalance: amount,\n };\n}\n\nexport async function buildWithdrawTx(\n client: SuiJsonRpcClient,\n address: string,\n amount: number,\n): Promise<{ tx: Transaction; effectiveAmount: number }> {\n const [config, pool, pools, states] = await Promise.all([\n getConfig(),\n getUsdcPool(),\n getPools(),\n getUserState(client, address),\n ]);\n\n const usdcState = states.find((s) => s.assetId === pool.id);\n const deposited = usdcState ? compoundBalance(usdcState.supplyBalance, pool.currentSupplyIndex) : 0;\n\n const effectiveAmount = Math.min(amount, Math.max(0, deposited - WITHDRAW_DUST_BUFFER));\n if (effectiveAmount <= 0) throw new T2000Error('NO_COLLATERAL', 'Nothing to withdraw');\n\n const rawAmount = Number(usdcToRaw(effectiveAmount));\n const tx = new Transaction();\n tx.setSender(address);\n\n addOracleUpdate(tx, config, pool);\n\n const [balance] = tx.moveCall({\n target: `${config.package}::incentive_v3::withdraw_v2`,\n arguments: [\n tx.object(CLOCK),\n tx.object(config.oracle.priceOracle),\n tx.object(config.storage),\n tx.object(pool.contract.pool),\n tx.pure.u8(pool.id),\n tx.pure.u64(rawAmount),\n tx.object(config.incentiveV2),\n tx.object(config.incentiveV3),\n tx.object(SUI_SYSTEM_STATE),\n ],\n typeArguments: [pool.suiCoinType],\n });\n\n const [coin] = tx.moveCall({\n target: '0x2::coin::from_balance',\n arguments: [balance],\n typeArguments: [pool.suiCoinType],\n });\n\n tx.transferObjects([coin], address);\n\n return { tx, effectiveAmount };\n}\n\nexport async function withdraw(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n amount: number,\n): Promise<WithdrawResult> {\n const address = keypair.getPublicKey().toSuiAddress();\n const { tx, effectiveAmount } = await buildWithdrawTx(client, address, amount);\n\n const result = await client.signAndExecuteTransaction({\n signer: keypair,\n transaction: tx,\n options: { showEffects: true },\n });\n await client.waitForTransaction({ digest: result.digest });\n\n return {\n success: true,\n tx: result.digest,\n amount: effectiveAmount,\n gasCost: extractGasCost(result.effects),\n gasMethod: 'self-funded' as GasMethod,\n };\n}\n\nexport async function buildBorrowTx(\n client: SuiJsonRpcClient,\n address: string,\n amount: number,\n options: { collectFee?: boolean } = {},\n): Promise<Transaction> {\n if (!amount || amount <= 0 || !Number.isFinite(amount)) {\n throw new T2000Error('INVALID_AMOUNT', 'Borrow amount must be a positive number');\n }\n const rawAmount = Number(usdcToRaw(amount));\n const [config, pool] = await Promise.all([getConfig(), getUsdcPool()]);\n\n const tx = new Transaction();\n tx.setSender(address);\n\n addOracleUpdate(tx, config, pool);\n\n const [balance] = tx.moveCall({\n target: `${config.package}::incentive_v3::borrow_v2`,\n arguments: [\n tx.object(CLOCK),\n tx.object(config.oracle.priceOracle),\n tx.object(config.storage),\n tx.object(pool.contract.pool),\n tx.pure.u8(pool.id),\n tx.pure.u64(rawAmount),\n tx.object(config.incentiveV2),\n tx.object(config.incentiveV3),\n tx.object(SUI_SYSTEM_STATE),\n ],\n typeArguments: [pool.suiCoinType],\n });\n\n const [borrowedCoin] = tx.moveCall({\n target: '0x2::coin::from_balance',\n arguments: [balance],\n typeArguments: [pool.suiCoinType],\n });\n\n if (options.collectFee) {\n addCollectFeeToTx(tx, borrowedCoin, 'borrow');\n }\n\n tx.transferObjects([borrowedCoin], address);\n\n return tx;\n}\n\nexport async function borrow(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n amount: number,\n): Promise<BorrowResult> {\n const address = keypair.getPublicKey().toSuiAddress();\n const tx = await buildBorrowTx(client, address, amount);\n\n const result = await client.signAndExecuteTransaction({\n signer: keypair,\n transaction: tx,\n options: { showEffects: true },\n });\n await client.waitForTransaction({ digest: result.digest });\n\n const hfResult = await getHealthFactor(client, address);\n\n return {\n success: true,\n tx: result.digest,\n amount,\n fee: 0,\n healthFactor: hfResult.healthFactor,\n gasCost: extractGasCost(result.effects),\n gasMethod: 'self-funded' as GasMethod,\n };\n}\n\nexport async function buildRepayTx(\n client: SuiJsonRpcClient,\n address: string,\n amount: number,\n): Promise<Transaction> {\n if (!amount || amount <= 0 || !Number.isFinite(amount)) {\n throw new T2000Error('INVALID_AMOUNT', 'Repay amount must be a positive number');\n }\n const rawAmount = Number(usdcToRaw(amount));\n const [config, pool] = await Promise.all([getConfig(), getUsdcPool()]);\n\n const coins = await fetchCoins(client, address, USDC_TYPE);\n if (coins.length === 0) throw new T2000Error('INSUFFICIENT_BALANCE', 'No USDC coins to repay with');\n\n const tx = new Transaction();\n tx.setSender(address);\n\n addOracleUpdate(tx, config, pool);\n\n const coinObj = mergeCoins(tx, coins);\n\n tx.moveCall({\n target: `${config.package}::incentive_v3::entry_repay`,\n arguments: [\n tx.object(CLOCK),\n tx.object(config.oracle.priceOracle),\n tx.object(config.storage),\n tx.object(pool.contract.pool),\n tx.pure.u8(pool.id),\n coinObj,\n tx.pure.u64(rawAmount),\n tx.object(config.incentiveV2),\n tx.object(config.incentiveV3),\n ],\n typeArguments: [pool.suiCoinType],\n });\n\n return tx;\n}\n\nexport async function repay(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n amount: number,\n): Promise<RepayResult> {\n const address = keypair.getPublicKey().toSuiAddress();\n const tx = await buildRepayTx(client, address, amount);\n\n const result = await client.signAndExecuteTransaction({\n signer: keypair,\n transaction: tx,\n options: { showEffects: true },\n });\n await client.waitForTransaction({ digest: result.digest });\n\n const states = await getUserState(client, address);\n const pool = await getUsdcPool();\n const usdcState = states.find((s) => s.assetId === pool.id);\n const remainingDebt = usdcState ? compoundBalance(usdcState.borrowBalance, pool.currentBorrowIndex) : 0;\n\n return {\n success: true,\n tx: result.digest,\n amount,\n remainingDebt,\n gasCost: extractGasCost(result.effects),\n gasMethod: 'self-funded' as GasMethod,\n };\n}\n\nexport async function getHealthFactor(\n client: SuiJsonRpcClient,\n addressOrKeypair: string | Ed25519Keypair,\n): Promise<HealthFactorResult> {\n const address = typeof addressOrKeypair === 'string'\n ? addressOrKeypair\n : addressOrKeypair.getPublicKey().toSuiAddress();\n\n const [config, pool, states] = await Promise.all([\n getConfig(),\n getUsdcPool(),\n getUserState(client, address),\n ]);\n\n const usdcState = states.find((s) => s.assetId === pool.id);\n const supplied = usdcState ? compoundBalance(usdcState.supplyBalance, pool.currentSupplyIndex) : 0;\n const borrowed = usdcState ? compoundBalance(usdcState.borrowBalance, pool.currentBorrowIndex) : 0;\n\n const ltv = parseLtv(pool.ltv);\n const liqThreshold = parseLiqThreshold(pool.liquidationFactor.threshold);\n const maxBorrowVal = Math.max(0, supplied * ltv - borrowed);\n\n let healthFactor: number;\n if (borrowed <= 0) {\n healthFactor = Infinity;\n } else {\n try {\n const tx = new Transaction();\n tx.moveCall({\n target: `${config.uiGetter}::calculator_unchecked::dynamic_health_factor`,\n arguments: [\n tx.object(CLOCK),\n tx.object(config.storage),\n tx.object(config.oracle.priceOracle),\n tx.pure.u8(pool.id),\n tx.pure.address(address),\n tx.pure.u8(pool.id),\n tx.pure.u64(0),\n tx.pure.u64(0),\n tx.pure.bool(false),\n ],\n typeArguments: [pool.suiCoinType],\n });\n\n const result = await client.devInspectTransactionBlock({\n transactionBlock: tx,\n sender: address,\n });\n\n const decoded = decodeDevInspect(result, bcs.u256());\n if (decoded !== undefined) {\n healthFactor = normalizeHealthFactor(Number(decoded));\n } else {\n healthFactor = borrowed > 0 ? (supplied * liqThreshold) / borrowed : Infinity;\n }\n } catch {\n healthFactor = borrowed > 0 ? (supplied * liqThreshold) / borrowed : Infinity;\n }\n }\n\n return {\n healthFactor,\n supplied,\n borrowed,\n maxBorrow: maxBorrowVal,\n liquidationThreshold: liqThreshold,\n };\n}\n\nexport async function getRates(client: SuiJsonRpcClient): Promise<RatesResult> {\n try {\n const pool = await getUsdcPool();\n\n let saveApy = rateToApy(pool.currentSupplyRate);\n let borrowApy = rateToApy(pool.currentBorrowRate);\n\n if (saveApy <= 0 || saveApy > 100) saveApy = 4.0;\n if (borrowApy <= 0 || borrowApy > 100) borrowApy = 6.0;\n\n return { USDC: { saveApy, borrowApy } };\n } catch {\n return { USDC: { saveApy: 4.0, borrowApy: 6.0 } };\n }\n}\n\nexport async function getPositions(\n client: SuiJsonRpcClient,\n addressOrKeypair: string | Ed25519Keypair,\n): Promise<PositionsResult> {\n const address = typeof addressOrKeypair === 'string'\n ? addressOrKeypair\n : addressOrKeypair.getPublicKey().toSuiAddress();\n\n const [states, pools] = await Promise.all([getUserState(client, address), getPools()]);\n const positions: PositionEntry[] = [];\n\n for (const state of states) {\n const pool = pools.find((p) => p.id === state.assetId);\n if (!pool) continue;\n\n const symbol = pool.token?.symbol ?? 'UNKNOWN';\n const supplyBal = compoundBalance(state.supplyBalance, pool.currentSupplyIndex);\n const borrowBal = compoundBalance(state.borrowBalance, pool.currentBorrowIndex);\n\n if (supplyBal > 0.0001) {\n positions.push({\n protocol: 'navi',\n asset: symbol,\n type: 'save',\n amount: supplyBal,\n apy: rateToApy(pool.currentSupplyRate),\n });\n }\n\n if (borrowBal > 0.0001) {\n positions.push({\n protocol: 'navi',\n asset: symbol,\n type: 'borrow',\n amount: borrowBal,\n apy: rateToApy(pool.currentBorrowRate),\n });\n }\n }\n\n return { positions };\n}\n\nexport async function maxWithdrawAmount(\n client: SuiJsonRpcClient,\n addressOrKeypair: string | Ed25519Keypair,\n): Promise<MaxWithdrawResult> {\n const hf = await getHealthFactor(client, addressOrKeypair);\n const ltv = hf.liquidationThreshold > 0 ? hf.liquidationThreshold : 0.75;\n\n let maxAmount: number;\n if (hf.borrowed === 0) {\n maxAmount = hf.supplied;\n } else {\n maxAmount = Math.max(0, hf.supplied - (hf.borrowed * MIN_HEALTH_FACTOR / ltv));\n }\n\n const remainingSupply = hf.supplied - maxAmount;\n const hfAfter = hf.borrowed > 0 ? remainingSupply / hf.borrowed : Infinity;\n\n return { maxAmount, healthFactorAfter: hfAfter, currentHF: hf.healthFactor };\n}\n\nexport async function maxBorrowAmount(\n client: SuiJsonRpcClient,\n addressOrKeypair: string | Ed25519Keypair,\n): Promise<MaxBorrowResult> {\n const hf = await getHealthFactor(client, addressOrKeypair);\n const ltv = hf.liquidationThreshold > 0 ? hf.liquidationThreshold : 0.75;\n\n const maxAmount = Math.max(0, hf.supplied * ltv / MIN_HEALTH_FACTOR - hf.borrowed);\n\n return { maxAmount, healthFactorAfter: MIN_HEALTH_FACTOR, currentHF: hf.healthFactor };\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type { Ed25519Keypair } from '@mysten/sui/keypairs/ed25519';\nimport * as navi from './navi.js';\nimport type { EarningsResult, FundStatusResult } from '../types.js';\n\nexport async function getEarnings(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n): Promise<EarningsResult> {\n const hf = await navi.getHealthFactor(client, keypair);\n const rates = await navi.getRates(client);\n\n const supplied = hf.supplied;\n const apy = rates.USDC.saveApy / 100;\n const dailyRate = apy / 365;\n const dailyEarning = supplied * dailyRate;\n\n // Estimate total yield earned based on position age\n // For MVP, use a simple approximation\n const totalYieldEarned = dailyEarning * 30; // rough monthly estimate\n\n return {\n totalYieldEarned,\n currentApy: rates.USDC.saveApy,\n dailyEarning,\n supplied,\n };\n}\n\nexport async function getFundStatus(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n): Promise<FundStatusResult> {\n const earnings = await getEarnings(client, keypair);\n\n return {\n supplied: earnings.supplied,\n apy: earnings.currentApy,\n earnedToday: earnings.dailyEarning,\n earnedAllTime: earnings.totalYieldEarned,\n projectedMonthly: earnings.dailyEarning * 30,\n };\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type { Ed25519Keypair } from '@mysten/sui/keypairs/ed25519';\nimport { Transaction } from '@mysten/sui/transactions';\nimport { bcs } from '@mysten/sui/bcs';\nimport { SENTINEL, CLOCK_ID, MIST_PER_SUI } from '../constants.js';\nimport { T2000Error } from '../errors.js';\nimport type { SentinelAgent, SentinelVerdict, SentinelAttackResult } from '../types.js';\n\ninterface RawSentinelAgent {\n agent_id: string;\n agent_object_id: string;\n agent_name: string;\n cost_per_message: string;\n total_balance: string;\n total_attacks: number;\n successful_breaches?: number;\n state: string;\n prompt: string;\n model?: string;\n}\n\nfunction mapAgent(raw: RawSentinelAgent): SentinelAgent {\n return {\n id: raw.agent_id,\n objectId: raw.agent_object_id,\n name: raw.agent_name,\n model: raw.model ?? 'unknown',\n systemPrompt: raw.prompt,\n attackFee: BigInt(raw.cost_per_message),\n prizePool: BigInt(raw.total_balance),\n totalAttacks: raw.total_attacks,\n successfulBreaches: raw.successful_breaches ?? 0,\n state: raw.state,\n };\n}\n\nexport async function listSentinels(): Promise<SentinelAgent[]> {\n const res = await fetch(SENTINEL.SENTINELS_API);\n if (!res.ok) {\n throw new T2000Error('SENTINEL_API_ERROR', `Sentinel API returned ${res.status}`);\n }\n\n const data = (await res.json()) as { agents: RawSentinelAgent[] };\n if (!Array.isArray(data.agents)) {\n throw new T2000Error('SENTINEL_API_ERROR', 'Unexpected API response shape');\n }\n\n return data.agents\n .filter((a) => a.state === 'active')\n .map(mapAgent);\n}\n\nexport async function getSentinelInfo(\n client: SuiJsonRpcClient,\n sentinelObjectId: string,\n): Promise<SentinelAgent> {\n const agents = await listSentinels();\n const match = agents.find((a) => a.objectId === sentinelObjectId || a.id === sentinelObjectId);\n\n if (match) return match;\n\n const obj = await client.getObject({\n id: sentinelObjectId,\n options: { showContent: true, showType: true },\n });\n\n if (!obj.data) {\n throw new T2000Error('SENTINEL_NOT_FOUND', `Sentinel ${sentinelObjectId} not found on-chain`);\n }\n\n const content = obj.data.content;\n if (!content || content.dataType !== 'moveObject') {\n throw new T2000Error('SENTINEL_NOT_FOUND', `Object ${sentinelObjectId} is not a Move object`);\n }\n\n const fields = content.fields as Record<string, unknown>;\n\n return {\n id: (fields.id as { id: string })?.id ?? sentinelObjectId,\n objectId: sentinelObjectId,\n name: (fields.name as string) ?? 'Unknown',\n model: (fields.model as string) ?? 'unknown',\n systemPrompt: (fields.system_prompt as string) ?? '',\n attackFee: BigInt((fields.cost_per_message as string) ?? '0'),\n prizePool: BigInt((fields.balance as string) ?? '0'),\n totalAttacks: Number((fields.total_attacks as string) ?? '0'),\n successfulBreaches: Number((fields.successful_breaches as string) ?? '0'),\n state: (fields.state as string) ?? 'unknown',\n };\n}\n\nexport async function requestAttack(\n client: SuiJsonRpcClient,\n signer: Ed25519Keypair,\n sentinelObjectId: string,\n feeMist: bigint,\n): Promise<{ attackObjectId: string; digest: string }> {\n if (feeMist < SENTINEL.MIN_FEE_MIST) {\n throw new T2000Error('INVALID_AMOUNT', `Attack fee must be at least 0.1 SUI (${SENTINEL.MIN_FEE_MIST} MIST)`);\n }\n\n const tx = new Transaction();\n const [coin] = tx.splitCoins(tx.gas, [Number(feeMist)]);\n\n const [attack] = tx.moveCall({\n target: `${SENTINEL.PACKAGE}::sentinel::request_attack`,\n arguments: [\n tx.object(SENTINEL.AGENT_REGISTRY),\n tx.object(sentinelObjectId),\n tx.object(SENTINEL.PROTOCOL_CONFIG),\n coin,\n tx.object(SENTINEL.RANDOM),\n tx.object(CLOCK_ID),\n ],\n });\n\n const address = signer.toSuiAddress();\n tx.transferObjects([attack], address);\n\n const result = await client.signAndExecuteTransaction({\n signer,\n transaction: tx,\n options: { showObjectChanges: true, showEffects: true },\n });\n\n await client.waitForTransaction({ digest: result.digest });\n\n const attackObj = result.objectChanges?.find(\n (c) => c.type === 'created' && c.objectType?.includes('::sentinel::Attack'),\n );\n\n const attackObjectId = attackObj && 'objectId' in attackObj ? attackObj.objectId : undefined;\n\n if (!attackObjectId) {\n throw new T2000Error('SENTINEL_TX_FAILED', 'Attack object was not created — transaction may have failed');\n }\n\n return { attackObjectId, digest: result.digest };\n}\n\nexport async function submitPrompt(\n agentId: string,\n attackObjectId: string,\n prompt: string,\n): Promise<SentinelVerdict> {\n const res = await fetch(SENTINEL.TEE_API, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({\n agent_id: agentId,\n attack_object_id: attackObjectId,\n message: prompt,\n }),\n });\n\n if (!res.ok) {\n const body = await res.text().catch(() => '');\n throw new T2000Error('SENTINEL_TEE_ERROR', `TEE returned ${res.status}: ${body.slice(0, 200)}`);\n }\n\n const raw = await res.json() as Record<string, unknown>;\n\n // TEE wraps: { response: { intent, timestamp_ms, data: { ... } }, signature }\n const envelope = (raw.response ?? raw) as Record<string, unknown>;\n const data = (envelope.data ?? envelope) as Record<string, unknown>;\n const signature = (raw.signature ?? data.signature) as string;\n const timestampMs = (envelope.timestamp_ms ?? data.timestamp_ms) as number;\n\n if (typeof signature !== 'string') {\n throw new T2000Error('SENTINEL_TEE_ERROR', 'TEE response missing signature');\n }\n\n return {\n success: (data.success ?? data.is_success) as boolean,\n score: data.score as number,\n agentResponse: data.agent_response as string,\n juryResponse: data.jury_response as string,\n funResponse: (data.fun_response as string) ?? '',\n signature,\n timestampMs,\n };\n}\n\nexport async function settleAttack(\n client: SuiJsonRpcClient,\n signer: Ed25519Keypair,\n sentinelObjectId: string,\n attackObjectId: string,\n prompt: string,\n verdict: SentinelVerdict,\n): Promise<{ digest: string; success: boolean }> {\n const sigBytes = Array.from(Buffer.from(verdict.signature.replace(/^0x/, ''), 'hex'));\n\n const tx = new Transaction();\n tx.moveCall({\n target: `${SENTINEL.PACKAGE}::sentinel::consume_prompt`,\n arguments: [\n tx.object(SENTINEL.AGENT_REGISTRY),\n tx.object(SENTINEL.PROTOCOL_CONFIG),\n tx.object(sentinelObjectId),\n tx.pure.bool(verdict.success),\n tx.pure.string(verdict.agentResponse),\n tx.pure.string(verdict.juryResponse),\n tx.pure.string(verdict.funResponse),\n tx.pure.string(prompt),\n tx.pure.u8(verdict.score),\n tx.pure.u64(verdict.timestampMs),\n tx.pure(bcs.vector(bcs.u8()).serialize(sigBytes)),\n tx.object(SENTINEL.ENCLAVE),\n tx.object(attackObjectId),\n tx.object(CLOCK_ID),\n ],\n });\n\n const result = await client.signAndExecuteTransaction({\n signer,\n transaction: tx,\n options: { showEffects: true },\n });\n\n await client.waitForTransaction({ digest: result.digest });\n\n const txSuccess = result.effects?.status?.status === 'success';\n\n return { digest: result.digest, success: txSuccess };\n}\n\nexport async function attack(\n client: SuiJsonRpcClient,\n signer: Ed25519Keypair,\n sentinelId: string,\n prompt: string,\n feeMist?: bigint,\n): Promise<SentinelAttackResult> {\n const sentinel = await getSentinelInfo(client, sentinelId);\n const fee = feeMist ?? sentinel.attackFee;\n\n if (fee < SENTINEL.MIN_FEE_MIST) {\n throw new T2000Error('INVALID_AMOUNT', `Attack fee must be at least 0.1 SUI`);\n }\n\n const { attackObjectId, digest: requestTx } = await requestAttack(\n client,\n signer,\n sentinel.objectId,\n fee,\n );\n\n const verdict = await submitPrompt(sentinel.id, attackObjectId, prompt);\n\n const { digest: settleTx } = await settleAttack(\n client,\n signer,\n sentinel.objectId,\n attackObjectId,\n prompt,\n verdict,\n );\n\n const won = verdict.success && verdict.score >= 70;\n\n return {\n attackObjectId,\n sentinelId: sentinel.id,\n prompt,\n verdict,\n requestTx,\n settleTx,\n won,\n feePaid: Number(fee) / Number(MIST_PER_SUI),\n };\n}\n","import type {\n LendingAdapter,\n SwapAdapter,\n LendingRates,\n SwapQuote,\n AdapterPositions,\n} from './types.js';\nimport { T2000Error } from '../errors.js';\n\nexport class ProtocolRegistry {\n private lending: Map<string, LendingAdapter> = new Map();\n private swap: Map<string, SwapAdapter> = new Map();\n\n registerLending(adapter: LendingAdapter): void {\n this.lending.set(adapter.id, adapter);\n }\n\n registerSwap(adapter: SwapAdapter): void {\n this.swap.set(adapter.id, adapter);\n }\n\n async bestSaveRate(asset: string): Promise<{ adapter: LendingAdapter; rate: LendingRates }> {\n const candidates: Array<{ adapter: LendingAdapter; rate: LendingRates }> = [];\n\n for (const adapter of this.lending.values()) {\n if (!adapter.supportedAssets.includes(asset)) continue;\n if (!adapter.capabilities.includes('save')) continue;\n try {\n const rate = await adapter.getRates(asset);\n candidates.push({ adapter, rate });\n } catch {\n // skip adapters that fail to fetch rates\n }\n }\n\n if (candidates.length === 0) {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `No lending adapter supports saving ${asset}`);\n }\n\n candidates.sort((a, b) => b.rate.saveApy - a.rate.saveApy);\n return candidates[0];\n }\n\n async bestBorrowRate(asset: string, opts?: { requireSameAssetBorrow?: boolean }): Promise<{ adapter: LendingAdapter; rate: LendingRates }> {\n const candidates: Array<{ adapter: LendingAdapter; rate: LendingRates }> = [];\n\n for (const adapter of this.lending.values()) {\n if (!adapter.supportedAssets.includes(asset)) continue;\n if (!adapter.capabilities.includes('borrow')) continue;\n if (opts?.requireSameAssetBorrow && !adapter.supportsSameAssetBorrow) continue;\n try {\n const rate = await adapter.getRates(asset);\n candidates.push({ adapter, rate });\n } catch {\n // skip\n }\n }\n\n if (candidates.length === 0) {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `No lending adapter supports borrowing ${asset}`);\n }\n\n candidates.sort((a, b) => a.rate.borrowApy - b.rate.borrowApy);\n return candidates[0];\n }\n\n async bestSwapQuote(from: string, to: string, amount: number): Promise<{ adapter: SwapAdapter; quote: SwapQuote }> {\n const candidates: Array<{ adapter: SwapAdapter; quote: SwapQuote }> = [];\n\n for (const adapter of this.swap.values()) {\n const pairs = adapter.getSupportedPairs();\n if (!pairs.some(p => p.from === from && p.to === to)) continue;\n try {\n const quote = await adapter.getQuote(from, to, amount);\n candidates.push({ adapter, quote });\n } catch {\n // skip\n }\n }\n\n if (candidates.length === 0) {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `No swap adapter supports ${from} → ${to}`);\n }\n\n candidates.sort((a, b) => b.quote.expectedOutput - a.quote.expectedOutput);\n return candidates[0];\n }\n\n async allRates(asset: string): Promise<Array<{ protocol: string; protocolId: string; rates: LendingRates }>> {\n const results: Array<{ protocol: string; protocolId: string; rates: LendingRates }> = [];\n for (const adapter of this.lending.values()) {\n if (!adapter.supportedAssets.includes(asset)) continue;\n try {\n const rates = await adapter.getRates(asset);\n results.push({ protocol: adapter.name, protocolId: adapter.id, rates });\n } catch {\n // skip\n }\n }\n return results;\n }\n\n async allPositions(address: string): Promise<Array<{ protocol: string; protocolId: string; positions: AdapterPositions }>> {\n const results: Array<{ protocol: string; protocolId: string; positions: AdapterPositions }> = [];\n for (const adapter of this.lending.values()) {\n try {\n const positions = await adapter.getPositions(address);\n if (positions.supplies.length > 0 || positions.borrows.length > 0) {\n results.push({ protocol: adapter.name, protocolId: adapter.id, positions });\n }\n } catch {\n // skip\n }\n }\n return results;\n }\n\n getLending(id: string): LendingAdapter | undefined {\n return this.lending.get(id);\n }\n\n getSwap(id: string): SwapAdapter | undefined {\n return this.swap.get(id);\n }\n\n listLending(): LendingAdapter[] {\n return [...this.lending.values()];\n }\n\n listSwap(): SwapAdapter[] {\n return [...this.swap.values()];\n }\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type {\n LendingAdapter,\n LendingRates,\n AdapterPositions,\n HealthInfo,\n AdapterTxResult,\n AdapterCapability,\n} from './types.js';\nimport { T2000Error } from '../errors.js';\nimport * as naviProtocol from '../protocols/navi.js';\n\nexport class NaviAdapter implements LendingAdapter {\n readonly id = 'navi';\n readonly name = 'NAVI Protocol';\n readonly version = '1.0.0';\n readonly capabilities: readonly AdapterCapability[] = ['save', 'withdraw', 'borrow', 'repay'];\n readonly supportedAssets: readonly string[] = ['USDC'];\n readonly supportsSameAssetBorrow = true;\n\n private client!: SuiJsonRpcClient;\n\n async init(client: SuiJsonRpcClient): Promise<void> {\n this.client = client;\n }\n\n initSync(client: SuiJsonRpcClient): void {\n this.client = client;\n }\n\n async getRates(asset: string): Promise<LendingRates> {\n const rates = await naviProtocol.getRates(this.client);\n const key = asset.toUpperCase() as keyof typeof rates;\n const r = rates[key];\n if (!r) throw new T2000Error('ASSET_NOT_SUPPORTED', `NAVI does not support ${asset}`);\n return { asset, saveApy: r.saveApy, borrowApy: r.borrowApy };\n }\n\n async getPositions(address: string): Promise<AdapterPositions> {\n const result = await naviProtocol.getPositions(this.client, address);\n return {\n supplies: result.positions\n .filter(p => p.type === 'save')\n .map(p => ({ asset: p.asset, amount: p.amount, apy: p.apy })),\n borrows: result.positions\n .filter(p => p.type === 'borrow')\n .map(p => ({ asset: p.asset, amount: p.amount, apy: p.apy })),\n };\n }\n\n async getHealth(address: string): Promise<HealthInfo> {\n return naviProtocol.getHealthFactor(this.client, address);\n }\n\n async buildSaveTx(\n address: string,\n amount: number,\n _asset: string,\n options?: { collectFee?: boolean },\n ): Promise<AdapterTxResult> {\n const tx = await naviProtocol.buildSaveTx(this.client, address, amount, options);\n return { tx };\n }\n\n async buildWithdrawTx(\n address: string,\n amount: number,\n _asset: string,\n ): Promise<AdapterTxResult & { effectiveAmount: number }> {\n const result = await naviProtocol.buildWithdrawTx(this.client, address, amount);\n return { tx: result.tx, effectiveAmount: result.effectiveAmount };\n }\n\n async buildBorrowTx(\n address: string,\n amount: number,\n _asset: string,\n options?: { collectFee?: boolean },\n ): Promise<AdapterTxResult> {\n const tx = await naviProtocol.buildBorrowTx(this.client, address, amount, options);\n return { tx };\n }\n\n async buildRepayTx(\n address: string,\n amount: number,\n _asset: string,\n ): Promise<AdapterTxResult> {\n const tx = await naviProtocol.buildRepayTx(this.client, address, amount);\n return { tx };\n }\n\n async maxWithdraw(address: string, _asset: string) {\n return naviProtocol.maxWithdrawAmount(this.client, address);\n }\n\n async maxBorrow(address: string, _asset: string) {\n return naviProtocol.maxBorrowAmount(this.client, address);\n }\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type { Ed25519Keypair } from '@mysten/sui/keypairs/ed25519';\nimport { Transaction } from '@mysten/sui/transactions';\nimport { AggregatorClient, Env } from '@cetusprotocol/aggregator-sdk';\nimport { SUPPORTED_ASSETS, CETUS_USDC_SUI_POOL } from '../constants.js';\nimport { T2000Error } from '../errors.js';\nimport type { GasMethod } from '../types.js';\n\nconst DEFAULT_SLIPPAGE_BPS = 300; // 3%\n\nexport interface SwapParams {\n client: SuiJsonRpcClient;\n keypair: Ed25519Keypair;\n fromAsset: 'USDC' | 'SUI';\n toAsset: 'USDC' | 'SUI';\n amount: number;\n maxSlippageBps?: number;\n}\n\nexport interface SwapTxResult {\n digest: string;\n fromAmount: number;\n fromAsset: string;\n toAmount: number;\n toAsset: string;\n priceImpact: number;\n gasCost: number;\n}\n\nfunction extractGasCost(\n effects: { gasUsed?: { computationCost: string; storageCost: string; storageRebate: string } } | undefined | null,\n): number {\n if (!effects?.gasUsed) return 0;\n return (\n Number(effects.gasUsed.computationCost) +\n Number(effects.gasUsed.storageCost) -\n Number(effects.gasUsed.storageRebate)\n ) / 1e9;\n}\n\nexport interface SwapBuildResult {\n tx: Transaction;\n estimatedOut: number;\n toDecimals: number;\n}\n\nfunction createAggregatorClient(client: SuiJsonRpcClient, signer?: string): AggregatorClient {\n // Cetus SDK bundles @mysten/sui v1 internally — the runtime API is\n // identical to SuiJsonRpcClient, so the cast is safe.\n return new AggregatorClient({\n client: client as never,\n signer,\n env: Env.Mainnet,\n });\n}\n\nexport async function buildSwapTx(params: {\n client: SuiJsonRpcClient;\n address: string;\n fromAsset: 'USDC' | 'SUI';\n toAsset: 'USDC' | 'SUI';\n amount: number;\n maxSlippageBps?: number;\n}): Promise<SwapBuildResult> {\n const { client, address, fromAsset, toAsset, amount, maxSlippageBps = DEFAULT_SLIPPAGE_BPS } = params;\n\n const fromInfo = SUPPORTED_ASSETS[fromAsset];\n const toInfo = SUPPORTED_ASSETS[toAsset];\n const rawAmount = BigInt(Math.floor(amount * 10 ** fromInfo.decimals));\n\n const aggClient = createAggregatorClient(client, address);\n\n const result = await aggClient.findRouters({\n from: fromInfo.type,\n target: toInfo.type,\n amount: rawAmount,\n byAmountIn: true,\n });\n\n if (!result || result.insufficientLiquidity) {\n throw new T2000Error(\n 'ASSET_NOT_SUPPORTED',\n `No swap route found for ${fromAsset} → ${toAsset}`,\n );\n }\n\n const tx = new Transaction();\n const slippage = maxSlippageBps / 10000;\n\n await aggClient.fastRouterSwap({\n router: result,\n txb: tx as never,\n slippage,\n });\n\n const estimatedOut = Number(result.amountOut.toString());\n\n return {\n tx,\n estimatedOut,\n toDecimals: toInfo.decimals,\n };\n}\n\nexport async function executeSwap(params: SwapParams): Promise<SwapTxResult> {\n const { client, keypair, fromAsset, toAsset, amount, maxSlippageBps } = params;\n const address = keypair.getPublicKey().toSuiAddress();\n const toInfo = SUPPORTED_ASSETS[toAsset];\n\n const { tx, estimatedOut, toDecimals } = await buildSwapTx({\n client,\n address,\n fromAsset,\n toAsset,\n amount,\n maxSlippageBps,\n });\n\n const result = await client.signAndExecuteTransaction({\n signer: keypair,\n transaction: tx,\n options: { showEffects: true, showBalanceChanges: true },\n });\n\n await client.waitForTransaction({ digest: result.digest });\n\n let actualReceived = 0;\n if (result.balanceChanges) {\n for (const change of result.balanceChanges) {\n if (\n change.coinType === toInfo.type &&\n change.owner &&\n typeof change.owner === 'object' &&\n 'AddressOwner' in change.owner &&\n change.owner.AddressOwner === address\n ) {\n const amt = Number(change.amount) / 10 ** toInfo.decimals;\n if (amt > 0) actualReceived += amt;\n }\n }\n }\n\n const expectedOutput = estimatedOut / 10 ** toDecimals;\n if (actualReceived === 0) actualReceived = expectedOutput;\n\n const priceImpact = expectedOutput > 0\n ? Math.abs(actualReceived - expectedOutput) / expectedOutput\n : 0;\n\n return {\n digest: result.digest,\n fromAmount: amount,\n fromAsset,\n toAmount: actualReceived,\n toAsset,\n priceImpact,\n gasCost: extractGasCost(result.effects as Parameters<typeof extractGasCost>[0]),\n };\n}\n\nexport async function getPoolPrice(client: SuiJsonRpcClient): Promise<number> {\n try {\n const pool = await client.getObject({\n id: CETUS_USDC_SUI_POOL,\n options: { showContent: true },\n });\n\n if (pool.data?.content?.dataType === 'moveObject') {\n const fields = pool.data.content.fields as Record<string, unknown>;\n const currentSqrtPrice = BigInt(String(fields.current_sqrt_price ?? '0'));\n\n if (currentSqrtPrice > 0n) {\n const Q64 = 2n ** 64n;\n const sqrtPriceFloat = Number(currentSqrtPrice) / Number(Q64);\n const rawPrice = sqrtPriceFloat * sqrtPriceFloat;\n const suiPriceUsd = 1e3 / rawPrice;\n if (suiPriceUsd > 0.01 && suiPriceUsd < 1000) return suiPriceUsd;\n }\n }\n } catch {\n // Fallback\n }\n\n return 3.5;\n}\n\nexport async function getSwapQuote(\n client: SuiJsonRpcClient,\n fromAsset: 'USDC' | 'SUI',\n toAsset: 'USDC' | 'SUI',\n amount: number,\n): Promise<{ expectedOutput: number; priceImpact: number; poolPrice: number }> {\n const fromInfo = SUPPORTED_ASSETS[fromAsset];\n const toInfo = SUPPORTED_ASSETS[toAsset];\n const rawAmount = BigInt(Math.floor(amount * 10 ** fromInfo.decimals));\n\n const poolPrice = await getPoolPrice(client);\n\n try {\n const aggClient = createAggregatorClient(client);\n\n const result = await aggClient.findRouters({\n from: fromInfo.type,\n target: toInfo.type,\n amount: rawAmount,\n byAmountIn: true,\n });\n\n if (!result || result.insufficientLiquidity) {\n return fallbackQuote(fromAsset, amount, poolPrice);\n }\n\n const expectedOutput = Number(result.amountOut.toString()) / 10 ** toInfo.decimals;\n const priceImpact = result.deviationRatio ?? 0;\n\n return { expectedOutput, priceImpact, poolPrice };\n } catch {\n return fallbackQuote(fromAsset, amount, poolPrice);\n }\n}\n\nfunction fallbackQuote(\n fromAsset: string,\n amount: number,\n poolPrice: number,\n): { expectedOutput: number; priceImpact: number; poolPrice: number } {\n const expectedOutput = fromAsset === 'USDC'\n ? amount / poolPrice\n : amount * poolPrice;\n return { expectedOutput, priceImpact: 0, poolPrice };\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type {\n SwapAdapter,\n SwapQuote,\n AdapterTxResult,\n AdapterCapability,\n} from './types.js';\nimport * as cetusProtocol from '../protocols/cetus.js';\n\nexport class CetusAdapter implements SwapAdapter {\n readonly id = 'cetus';\n readonly name = 'Cetus';\n readonly version = '1.0.0';\n readonly capabilities: readonly AdapterCapability[] = ['swap'];\n\n private client!: SuiJsonRpcClient;\n\n async init(client: SuiJsonRpcClient): Promise<void> {\n this.client = client;\n }\n\n initSync(client: SuiJsonRpcClient): void {\n this.client = client;\n }\n\n async getQuote(from: string, to: string, amount: number): Promise<SwapQuote> {\n return cetusProtocol.getSwapQuote(\n this.client,\n from.toUpperCase() as 'USDC' | 'SUI',\n to.toUpperCase() as 'USDC' | 'SUI',\n amount,\n );\n }\n\n async buildSwapTx(\n address: string,\n from: string,\n to: string,\n amount: number,\n maxSlippageBps?: number,\n ): Promise<AdapterTxResult & { estimatedOut: number; toDecimals: number }> {\n const result = await cetusProtocol.buildSwapTx({\n client: this.client,\n address,\n fromAsset: from.toUpperCase() as 'USDC' | 'SUI',\n toAsset: to.toUpperCase() as 'USDC' | 'SUI',\n amount,\n maxSlippageBps,\n });\n return {\n tx: result.tx,\n estimatedOut: result.estimatedOut,\n toDecimals: result.toDecimals,\n };\n }\n\n getSupportedPairs(): Array<{ from: string; to: string }> {\n return [\n { from: 'USDC', to: 'SUI' },\n { from: 'SUI', to: 'USDC' },\n ];\n }\n\n async getPoolPrice(): Promise<number> {\n return cetusProtocol.getPoolPrice(this.client);\n }\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport { Transaction } from '@mysten/sui/transactions';\nimport { normalizeStructTag } from '@mysten/sui/utils';\nimport type {\n LendingAdapter,\n LendingRates,\n AdapterPositions,\n HealthInfo,\n AdapterTxResult,\n AdapterCapability,\n} from './types.js';\nimport { SUPPORTED_ASSETS } from '../constants.js';\nimport { usdcToRaw } from '../utils/format.js';\nimport { T2000Error } from '../errors.js';\nimport { addCollectFeeToTx } from '../protocols/protocolFee.js';\nimport type { TransactionObjectArgument } from '@mysten/sui/transactions';\n\nconst USDC_TYPE = SUPPORTED_ASSETS.USDC.type;\nconst WAD = 1e18;\nconst MIN_HEALTH_FACTOR = 1.5;\nconst CLOCK = '0x6';\n\nconst LENDING_MARKET_ID = '0x84030d26d85eaa7035084a057f2f11f701b7e2e4eda87551becbc7c97505ece1';\nconst LENDING_MARKET_TYPE = '0xf95b06141ed4a174f239417323bde3f209b972f5930d8521ea38a52aff3a6ddf::suilend::MAIN_POOL';\nconst SUILEND_PACKAGE = '0xf95b06141ed4a174f239417323bde3f209b972f5930d8521ea38a52aff3a6ddf';\nconst UPGRADE_CAP_ID = '0x3d4ef1859c3ee9fc72858f588b56a09da5466e64f8cc4e90a7b3b909fba8a7ae';\nconst FALLBACK_PUBLISHED_AT = '0xd2a67633ccb8de063163e25bcfca242929caf5cf1a26c2929dab519ee0b8f331';\n\ninterface Reserve {\n coinType: string;\n mintDecimals: number;\n availableAmount: number;\n borrowedAmountWad: number;\n ctokenSupply: number;\n unclaimedSpreadFeesWad: number;\n cumulativeBorrowRateWad: number;\n openLtvPct: number;\n closeLtvPct: number;\n spreadFeeBps: number;\n interestRateUtils: number[];\n interestRateAprs: number[];\n arrayIndex: number;\n}\n\ninterface ObligationCap {\n id: string;\n obligationId: string;\n}\n\ninterface Obligation {\n deposits: Array<{ coinType: string; ctokenAmount: number; reserveIdx: number }>;\n borrows: Array<{ coinType: string; borrowedWad: number; cumBorrowRateWad: number; reserveIdx: number }>;\n}\n\n// ---------------------------------------------------------------------------\n// Rate math (unchanged from SDK-based version)\n// ---------------------------------------------------------------------------\n\nfunction interpolateRate(\n utilBreakpoints: number[],\n aprBreakpoints: number[],\n utilizationPct: number,\n): number {\n if (utilBreakpoints.length === 0) return 0;\n if (utilizationPct <= utilBreakpoints[0]) return aprBreakpoints[0];\n if (utilizationPct >= utilBreakpoints[utilBreakpoints.length - 1]) {\n return aprBreakpoints[aprBreakpoints.length - 1];\n }\n\n for (let i = 1; i < utilBreakpoints.length; i++) {\n if (utilizationPct <= utilBreakpoints[i]) {\n const t =\n (utilizationPct - utilBreakpoints[i - 1]) /\n (utilBreakpoints[i] - utilBreakpoints[i - 1]);\n return aprBreakpoints[i - 1] + t * (aprBreakpoints[i] - aprBreakpoints[i - 1]);\n }\n }\n return aprBreakpoints[aprBreakpoints.length - 1];\n}\n\nfunction computeRates(reserve: Reserve): { borrowAprPct: number; depositAprPct: number } {\n const available = reserve.availableAmount / 10 ** reserve.mintDecimals;\n const borrowed = reserve.borrowedAmountWad / WAD / 10 ** reserve.mintDecimals;\n const totalDeposited = available + borrowed;\n const utilizationPct = totalDeposited > 0 ? (borrowed / totalDeposited) * 100 : 0;\n\n if (reserve.interestRateUtils.length === 0) return { borrowAprPct: 0, depositAprPct: 0 };\n\n const aprs = reserve.interestRateAprs.map((a) => a / 100);\n const borrowAprPct = interpolateRate(reserve.interestRateUtils, aprs, utilizationPct);\n const depositAprPct =\n (utilizationPct / 100) *\n (borrowAprPct / 100) *\n (1 - reserve.spreadFeeBps / 10000) *\n 100;\n\n return { borrowAprPct, depositAprPct };\n}\n\nfunction cTokenRatio(reserve: Reserve): number {\n if (reserve.ctokenSupply === 0) return 1;\n const totalSupply =\n reserve.availableAmount +\n reserve.borrowedAmountWad / WAD -\n reserve.unclaimedSpreadFeesWad / WAD;\n return totalSupply / reserve.ctokenSupply;\n}\n\n// ---------------------------------------------------------------------------\n// JSON-RPC response helpers\n// ---------------------------------------------------------------------------\n\ntype Fields = Record<string, unknown>;\n\nfunction f(obj: unknown): Fields {\n if (obj && typeof obj === 'object' && 'fields' in obj) return (obj as { fields: Fields }).fields;\n return obj as Fields;\n}\n\nfunction str(v: unknown): string { return String(v ?? '0'); }\nfunction num(v: unknown): number { return Number(str(v)); }\n\nfunction parseReserve(raw: unknown, index: number): Reserve {\n const r = f(raw);\n const coinTypeField = f(r.coin_type);\n const config = f(f(r.config)?.element);\n\n return {\n coinType: str(coinTypeField?.name),\n mintDecimals: num(r.mint_decimals),\n availableAmount: num(r.available_amount),\n borrowedAmountWad: num(f(r.borrowed_amount)?.value),\n ctokenSupply: num(r.ctoken_supply),\n unclaimedSpreadFeesWad: num(f(r.unclaimed_spread_fees)?.value),\n cumulativeBorrowRateWad: num(f(r.cumulative_borrow_rate)?.value),\n openLtvPct: num(config?.open_ltv_pct),\n closeLtvPct: num(config?.close_ltv_pct),\n spreadFeeBps: num(config?.spread_fee_bps),\n interestRateUtils: Array.isArray(config?.interest_rate_utils) ? (config.interest_rate_utils as unknown[]).map(num) : [],\n interestRateAprs: Array.isArray(config?.interest_rate_aprs) ? (config.interest_rate_aprs as unknown[]).map(num) : [],\n arrayIndex: index,\n };\n}\n\nfunction parseObligation(raw: Fields): Obligation {\n const deposits = Array.isArray(raw.deposits)\n ? (raw.deposits as unknown[]).map((d) => {\n const df = f(d);\n return {\n coinType: str(f(df.coin_type)?.name),\n ctokenAmount: num(df.deposited_ctoken_amount),\n reserveIdx: num(df.reserve_array_index),\n };\n })\n : [];\n\n const borrows = Array.isArray(raw.borrows)\n ? (raw.borrows as unknown[]).map((b) => {\n const bf = f(b);\n return {\n coinType: str(f(bf.coin_type)?.name),\n borrowedWad: num(f(bf.borrowed_amount)?.value),\n cumBorrowRateWad: num(f(bf.cumulative_borrow_rate)?.value),\n reserveIdx: num(bf.reserve_array_index),\n };\n })\n : [];\n\n return { deposits, borrows };\n}\n\n// ---------------------------------------------------------------------------\n// Adapter\n// ---------------------------------------------------------------------------\n\n/**\n * Suilend adapter — contract-first, no SDK dependency.\n * Interacts directly with Suilend Move contracts via RPC + PTB moveCall.\n */\nexport class SuilendAdapter implements LendingAdapter {\n readonly id = 'suilend';\n readonly name = 'Suilend';\n readonly version = '2.0.0';\n readonly capabilities: readonly AdapterCapability[] = ['save', 'withdraw'];\n readonly supportedAssets: readonly string[] = ['USDC'];\n readonly supportsSameAssetBorrow = false;\n\n private client!: SuiJsonRpcClient;\n private publishedAt: string | null = null;\n private reserveCache: Reserve[] | null = null;\n\n async init(client: SuiJsonRpcClient): Promise<void> {\n this.client = client;\n }\n\n initSync(client: SuiJsonRpcClient): void {\n this.client = client;\n }\n\n // -- On-chain reads -------------------------------------------------------\n\n private async resolvePackage(): Promise<string> {\n if (this.publishedAt) return this.publishedAt;\n try {\n const cap = await this.client.getObject({ id: UPGRADE_CAP_ID, options: { showContent: true } });\n if (cap.data?.content?.dataType === 'moveObject') {\n const fields = cap.data.content.fields as Fields;\n this.publishedAt = str(fields.package);\n return this.publishedAt;\n }\n } catch { /* use fallback */ }\n this.publishedAt = FALLBACK_PUBLISHED_AT;\n return this.publishedAt;\n }\n\n private async loadReserves(fresh = false): Promise<Reserve[]> {\n if (this.reserveCache && !fresh) return this.reserveCache;\n\n const market = await this.client.getObject({\n id: LENDING_MARKET_ID,\n options: { showContent: true },\n });\n\n if (market.data?.content?.dataType !== 'moveObject') {\n throw new T2000Error('PROTOCOL_UNAVAILABLE', 'Failed to read Suilend lending market');\n }\n\n const fields = market.data.content.fields as Fields;\n const reservesRaw = fields.reserves as unknown[];\n\n if (!Array.isArray(reservesRaw)) {\n throw new T2000Error('PROTOCOL_UNAVAILABLE', 'Failed to parse Suilend reserves');\n }\n\n this.reserveCache = reservesRaw.map((r, i) => parseReserve(r, i));\n return this.reserveCache;\n }\n\n private findReserve(reserves: Reserve[], asset: string): Reserve | undefined {\n const upper = asset.toUpperCase();\n let coinType: string;\n if (upper === 'USDC') coinType = USDC_TYPE;\n else if (upper === 'SUI') coinType = '0x2::sui::SUI';\n else if (asset.includes('::')) coinType = asset;\n else return undefined;\n\n try {\n const normalized = normalizeStructTag(coinType);\n return reserves.find((r) => {\n try { return normalizeStructTag(r.coinType) === normalized; } catch { return false; }\n });\n } catch { return undefined; }\n }\n\n private async fetchObligationCaps(address: string): Promise<ObligationCap[]> {\n const capType = `${SUILEND_PACKAGE}::lending_market::ObligationOwnerCap<${LENDING_MARKET_TYPE}>`;\n const caps: ObligationCap[] = [];\n let cursor: string | null | undefined;\n let hasNext = true;\n\n while (hasNext) {\n const page = await this.client.getOwnedObjects({\n owner: address,\n filter: { StructType: capType },\n options: { showContent: true },\n cursor: cursor ?? undefined,\n });\n\n for (const item of page.data) {\n if (item.data?.content?.dataType !== 'moveObject') continue;\n const fields = item.data.content.fields as Fields;\n caps.push({\n id: item.data.objectId,\n obligationId: str(fields.obligation_id),\n });\n }\n\n cursor = page.nextCursor;\n hasNext = page.hasNextPage;\n }\n\n return caps;\n }\n\n private async fetchObligation(obligationId: string): Promise<Obligation> {\n const obj = await this.client.getObject({ id: obligationId, options: { showContent: true } });\n if (obj.data?.content?.dataType !== 'moveObject') {\n throw new T2000Error('PROTOCOL_UNAVAILABLE', 'Failed to read Suilend obligation');\n }\n return parseObligation(obj.data.content.fields as Fields);\n }\n\n private resolveSymbol(coinType: string): string {\n try {\n const normalized = normalizeStructTag(coinType);\n if (normalized === normalizeStructTag(USDC_TYPE)) return 'USDC';\n if (normalized === normalizeStructTag('0x2::sui::SUI')) return 'SUI';\n } catch { /* fall through */ }\n const parts = coinType.split('::');\n return parts[parts.length - 1] || 'UNKNOWN';\n }\n\n // -- Adapter interface ----------------------------------------------------\n\n async getRates(asset: string): Promise<LendingRates> {\n const reserves = await this.loadReserves();\n const reserve = this.findReserve(reserves, asset);\n if (!reserve) throw new T2000Error('ASSET_NOT_SUPPORTED', `Suilend does not support ${asset}`);\n\n const { borrowAprPct, depositAprPct } = computeRates(reserve);\n return { asset, saveApy: depositAprPct, borrowApy: borrowAprPct };\n }\n\n async getPositions(address: string): Promise<AdapterPositions> {\n const supplies: Array<{ asset: string; amount: number; apy: number }> = [];\n const borrows: Array<{ asset: string; amount: number; apy: number }> = [];\n\n const caps = await this.fetchObligationCaps(address);\n if (caps.length === 0) return { supplies, borrows };\n\n const [reserves, obligation] = await Promise.all([\n this.loadReserves(),\n this.fetchObligation(caps[0].obligationId),\n ]);\n\n for (const dep of obligation.deposits) {\n const reserve = reserves[dep.reserveIdx];\n if (!reserve) continue;\n const ratio = cTokenRatio(reserve);\n const amount = (dep.ctokenAmount * ratio) / 10 ** reserve.mintDecimals;\n const { depositAprPct } = computeRates(reserve);\n supplies.push({ asset: this.resolveSymbol(dep.coinType), amount, apy: depositAprPct });\n }\n\n for (const bor of obligation.borrows) {\n const reserve = reserves[bor.reserveIdx];\n if (!reserve) continue;\n const rawAmount = bor.borrowedWad / WAD / 10 ** reserve.mintDecimals;\n const reserveRate = reserve.cumulativeBorrowRateWad / WAD;\n const posRate = bor.cumBorrowRateWad / WAD;\n const compounded = posRate > 0 ? rawAmount * (reserveRate / posRate) : rawAmount;\n const { borrowAprPct } = computeRates(reserve);\n borrows.push({ asset: this.resolveSymbol(bor.coinType), amount: compounded, apy: borrowAprPct });\n }\n\n return { supplies, borrows };\n }\n\n async getHealth(address: string): Promise<HealthInfo> {\n const caps = await this.fetchObligationCaps(address);\n if (caps.length === 0) {\n return { healthFactor: Infinity, supplied: 0, borrowed: 0, maxBorrow: 0, liquidationThreshold: 0 };\n }\n\n const positions = await this.getPositions(address);\n const supplied = positions.supplies.reduce((s, p) => s + p.amount, 0);\n const borrowed = positions.borrows.reduce((s, p) => s + p.amount, 0);\n\n const reserves = await this.loadReserves();\n const reserve = this.findReserve(reserves, 'USDC');\n const closeLtv = reserve?.closeLtvPct ?? 75;\n const openLtv = reserve?.openLtvPct ?? 70;\n const liqThreshold = closeLtv / 100;\n\n const healthFactor = borrowed > 0 ? (supplied * liqThreshold) / borrowed : Infinity;\n const maxBorrow = Math.max(0, supplied * (openLtv / 100) - borrowed);\n\n return { healthFactor, supplied, borrowed, maxBorrow, liquidationThreshold: liqThreshold };\n }\n\n async buildSaveTx(\n address: string,\n amount: number,\n _asset: string,\n options?: { collectFee?: boolean },\n ): Promise<AdapterTxResult> {\n const [pkg, reserves] = await Promise.all([this.resolvePackage(), this.loadReserves()]);\n const usdcReserve = this.findReserve(reserves, 'USDC');\n if (!usdcReserve) throw new T2000Error('ASSET_NOT_SUPPORTED', 'USDC reserve not found on Suilend');\n\n const caps = await this.fetchObligationCaps(address);\n const tx = new Transaction();\n tx.setSender(address);\n\n let capRef: TransactionObjectArgument | string;\n if (caps.length === 0) {\n const [newCap] = tx.moveCall({\n target: `${pkg}::lending_market::create_obligation`,\n typeArguments: [LENDING_MARKET_TYPE],\n arguments: [tx.object(LENDING_MARKET_ID)],\n });\n capRef = newCap;\n } else {\n capRef = caps[0].id;\n }\n\n const allCoins = await this.fetchAllCoins(address, USDC_TYPE);\n if (allCoins.length === 0) throw new T2000Error('INSUFFICIENT_BALANCE', 'No USDC coins found');\n\n const primaryCoinId = allCoins[0].coinObjectId;\n if (allCoins.length > 1) {\n tx.mergeCoins(tx.object(primaryCoinId), allCoins.slice(1).map((c) => tx.object(c.coinObjectId)));\n }\n\n const rawAmount = usdcToRaw(amount).toString();\n const [depositCoin] = tx.splitCoins(tx.object(primaryCoinId), [rawAmount]);\n\n if (options?.collectFee) {\n addCollectFeeToTx(tx, depositCoin as TransactionObjectArgument, 'save');\n }\n\n const [ctokens] = tx.moveCall({\n target: `${pkg}::lending_market::deposit_liquidity_and_mint_ctokens`,\n typeArguments: [LENDING_MARKET_TYPE, USDC_TYPE],\n arguments: [\n tx.object(LENDING_MARKET_ID),\n tx.pure.u64(usdcReserve.arrayIndex),\n tx.object(CLOCK),\n depositCoin,\n ],\n });\n\n tx.moveCall({\n target: `${pkg}::lending_market::deposit_ctokens_into_obligation`,\n typeArguments: [LENDING_MARKET_TYPE, USDC_TYPE],\n arguments: [\n tx.object(LENDING_MARKET_ID),\n tx.pure.u64(usdcReserve.arrayIndex),\n typeof capRef === 'string' ? tx.object(capRef) : capRef,\n tx.object(CLOCK),\n ctokens,\n ],\n });\n\n if (typeof capRef !== 'string') {\n tx.transferObjects([capRef], address);\n }\n\n return { tx };\n }\n\n async buildWithdrawTx(\n address: string,\n amount: number,\n _asset: string,\n ): Promise<AdapterTxResult & { effectiveAmount: number }> {\n const [pkg, reserves] = await Promise.all([this.resolvePackage(), this.loadReserves(true)]);\n const usdcReserve = this.findReserve(reserves, 'USDC');\n if (!usdcReserve) throw new T2000Error('ASSET_NOT_SUPPORTED', 'USDC reserve not found on Suilend');\n\n const caps = await this.fetchObligationCaps(address);\n if (caps.length === 0) throw new T2000Error('NO_COLLATERAL', 'No Suilend position found');\n\n const positions = await this.getPositions(address);\n const deposited = positions.supplies.find((s) => s.asset === 'USDC')?.amount ?? 0;\n const effectiveAmount = Math.min(amount, deposited);\n if (effectiveAmount <= 0) throw new T2000Error('NO_COLLATERAL', 'Nothing to withdraw from Suilend');\n\n const ratio = cTokenRatio(usdcReserve);\n const ctokenAmount = Math.ceil(effectiveAmount * 10 ** usdcReserve.mintDecimals / ratio);\n\n const tx = new Transaction();\n tx.setSender(address);\n\n const [ctokens] = tx.moveCall({\n target: `${pkg}::lending_market::withdraw_ctokens`,\n typeArguments: [LENDING_MARKET_TYPE, USDC_TYPE],\n arguments: [\n tx.object(LENDING_MARKET_ID),\n tx.pure.u64(usdcReserve.arrayIndex),\n tx.object(caps[0].id),\n tx.object(CLOCK),\n tx.pure.u64(ctokenAmount),\n ],\n });\n\n const exemptionType = `${SUILEND_PACKAGE}::lending_market::RateLimiterExemption<${LENDING_MARKET_TYPE}, ${USDC_TYPE}>`;\n const [none] = tx.moveCall({\n target: '0x1::option::none',\n typeArguments: [exemptionType],\n });\n\n const [coin] = tx.moveCall({\n target: `${pkg}::lending_market::redeem_ctokens_and_withdraw_liquidity`,\n typeArguments: [LENDING_MARKET_TYPE, USDC_TYPE],\n arguments: [\n tx.object(LENDING_MARKET_ID),\n tx.pure.u64(usdcReserve.arrayIndex),\n tx.object(CLOCK),\n ctokens,\n none,\n ],\n });\n\n tx.transferObjects([coin], address);\n\n return { tx, effectiveAmount };\n }\n\n async buildBorrowTx(\n _address: string,\n _amount: number,\n _asset: string,\n _options?: { collectFee?: boolean },\n ): Promise<AdapterTxResult> {\n throw new T2000Error('ASSET_NOT_SUPPORTED', 'Suilend borrow requires different collateral/borrow assets. Deferred to Phase 10.');\n }\n\n async buildRepayTx(\n _address: string,\n _amount: number,\n _asset: string,\n ): Promise<AdapterTxResult> {\n throw new T2000Error('ASSET_NOT_SUPPORTED', 'Suilend repay deferred to Phase 10.');\n }\n\n async maxWithdraw(\n address: string,\n _asset: string,\n ): Promise<{ maxAmount: number; healthFactorAfter: number; currentHF: number }> {\n const health = await this.getHealth(address);\n\n let maxAmount: number;\n if (health.borrowed === 0) {\n maxAmount = health.supplied;\n } else {\n maxAmount = Math.max(0, health.supplied - (health.borrowed * MIN_HEALTH_FACTOR) / health.liquidationThreshold);\n }\n\n const remainingSupply = health.supplied - maxAmount;\n const hfAfter = health.borrowed > 0\n ? (remainingSupply * health.liquidationThreshold) / health.borrowed\n : Infinity;\n\n return { maxAmount, healthFactorAfter: hfAfter, currentHF: health.healthFactor };\n }\n\n async maxBorrow(\n _address: string,\n _asset: string,\n ): Promise<{ maxAmount: number; healthFactorAfter: number; currentHF: number }> {\n throw new T2000Error('ASSET_NOT_SUPPORTED', 'Suilend maxBorrow deferred to Phase 10.');\n }\n\n private async fetchAllCoins(\n owner: string,\n coinType: string,\n ): Promise<Array<{ coinObjectId: string; balance: string }>> {\n const all: Array<{ coinObjectId: string; balance: string }> = [];\n let cursor: string | null | undefined = null;\n let hasNext = true;\n\n while (hasNext) {\n const page = await this.client.getCoins({ owner, coinType, cursor: cursor ?? undefined });\n all.push(...page.data.map((c) => ({ coinObjectId: c.coinObjectId, balance: c.balance })));\n cursor = page.nextCursor;\n hasNext = page.hasNextPage;\n }\n\n return all;\n }\n}\n","import { createHash } from 'node:crypto';\n\nfunction hasLeadingZeroBits(hash: Buffer, bits: number): boolean {\n const fullBytes = Math.floor(bits / 8);\n const remainingBits = bits % 8;\n\n for (let i = 0; i < fullBytes; i++) {\n if (hash[i] !== 0) return false;\n }\n\n if (remainingBits > 0) {\n const mask = 0xff << (8 - remainingBits);\n if ((hash[fullBytes] & mask) !== 0) return false;\n }\n\n return true;\n}\n\nexport function solveHashcash(challenge: string): string {\n const bits = parseInt(challenge.split(':')[1], 10);\n let counter = 0;\n while (true) {\n const stamp = `${challenge}${counter.toString(16)}`;\n const hash = createHash('sha256').update(stamp).digest();\n if (hasLeadingZeroBits(hash, bits)) return stamp;\n counter++;\n }\n}\n","import { API_BASE_URL } from '../constants.js';\nimport { T2000Error } from '../errors.js';\n\nexport type GasRequestType = 'bootstrap' | 'auto-topup' | 'fallback';\n\nexport interface GasSponsorResponse {\n txBytes: string;\n sponsorSignature: string;\n gasEstimateUsd: number;\n type: GasRequestType;\n}\n\nexport interface GasStatusResponse {\n circuitBreaker: boolean;\n suiPrice: number;\n bootstrapUsed?: number;\n bootstrapRemaining?: number;\n}\n\n/**\n * Request gas sponsorship from the gas station.\n *\n * Sends both `txJson` (preferred, v0.2.0+ server) and `txBytes` (base64-encoded\n * JSON for backward compat with v0.1.9 server). The server uses whichever field\n * it understands.\n */\nexport async function requestGasSponsorship(\n txJson: string,\n sender: string,\n type?: GasRequestType,\n): Promise<GasSponsorResponse> {\n const txBytes = Buffer.from(txJson).toString('base64');\n\n const res = await fetch(`${API_BASE_URL}/api/gas`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ txJson, txBytes, sender, type }),\n });\n\n const data = (await res.json()) as Record<string, unknown>;\n\n if (!res.ok) {\n const errorCode = data.error as string;\n\n if (errorCode === 'CIRCUIT_BREAKER' || errorCode === 'POOL_DEPLETED') {\n throw new T2000Error(\n 'GAS_STATION_UNAVAILABLE',\n (data.message as string) ?? 'Gas station temporarily unavailable',\n { retryAfter: data.retryAfter },\n true,\n );\n }\n if (errorCode === 'GAS_FEE_EXCEEDED') {\n throw new T2000Error(\n 'GAS_FEE_EXCEEDED',\n (data.message as string) ?? 'Gas fee exceeds ceiling',\n { retryAfter: data.retryAfter },\n true,\n );\n }\n\n throw new T2000Error(\n 'GAS_STATION_UNAVAILABLE',\n (data.message as string) ?? 'Gas sponsorship request failed',\n undefined,\n true,\n );\n }\n\n return data as unknown as GasSponsorResponse;\n}\n\nexport async function reportGasUsage(\n sender: string,\n txDigest: string,\n gasCostSui: number,\n usdcCharged: number,\n type: GasRequestType,\n): Promise<void> {\n try {\n await fetch(`${API_BASE_URL}/api/gas/report`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ sender, txDigest, gasCostSui, usdcCharged, type }),\n });\n } catch {\n // Non-critical — best-effort reporting\n }\n}\n\nexport async function getGasStatus(address?: string): Promise<GasStatusResponse> {\n const url = new URL(`${API_BASE_URL}/api/gas/status`);\n if (address) url.searchParams.set('address', address);\n\n const res = await fetch(url.toString());\n if (!res.ok) {\n throw new T2000Error('GAS_STATION_UNAVAILABLE', 'Failed to fetch gas status', undefined, true);\n }\n\n return (await res.json()) as GasStatusResponse;\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type { Ed25519Keypair } from '@mysten/sui/keypairs/ed25519';\nimport {\n SUPPORTED_ASSETS,\n AUTO_TOPUP_THRESHOLD,\n AUTO_TOPUP_AMOUNT,\n AUTO_TOPUP_MIN_USDC,\n MIST_PER_SUI,\n} from '../constants.js';\nimport { T2000Error } from '../errors.js';\nimport { buildSwapTx } from '../protocols/cetus.js';\nimport { requestGasSponsorship, reportGasUsage } from './gasStation.js';\n\nexport interface AutoTopUpResult {\n success: boolean;\n tx: string;\n usdcSpent: number;\n suiReceived: number;\n}\n\nexport async function shouldAutoTopUp(\n client: SuiJsonRpcClient,\n address: string,\n): Promise<boolean> {\n const [suiBalance, usdcBalance] = await Promise.all([\n client.getBalance({ owner: address, coinType: SUPPORTED_ASSETS.SUI.type }),\n client.getBalance({ owner: address, coinType: SUPPORTED_ASSETS.USDC.type }),\n ]);\n\n const suiRaw = BigInt(suiBalance.totalBalance);\n const usdcRaw = BigInt(usdcBalance.totalBalance);\n\n return suiRaw < AUTO_TOPUP_THRESHOLD && usdcRaw >= AUTO_TOPUP_MIN_USDC;\n}\n\nexport async function executeAutoTopUp(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n): Promise<AutoTopUpResult> {\n const address = keypair.getPublicKey().toSuiAddress();\n const topupAmountHuman = Number(AUTO_TOPUP_AMOUNT) / 1e6; // $1 USDC\n\n // Build swap tx via Cetus SDK (handles package upgrades automatically)\n const { tx } = await buildSwapTx({\n client,\n address,\n fromAsset: 'USDC',\n toAsset: 'SUI',\n amount: topupAmountHuman,\n });\n\n const txJson = tx.serialize();\n const sponsoredResult = await requestGasSponsorship(txJson, address, 'auto-topup');\n\n // Sign with agent key and submit\n const sponsoredTxBytes = Buffer.from(sponsoredResult.txBytes, 'base64');\n const { signature: agentSig } = await keypair.signTransaction(sponsoredTxBytes);\n\n const result = await client.executeTransactionBlock({\n transactionBlock: sponsoredResult.txBytes,\n signature: [agentSig, sponsoredResult.sponsorSignature],\n options: { showEffects: true, showBalanceChanges: true },\n });\n\n await client.waitForTransaction({ digest: result.digest });\n\n let suiReceived = 0;\n if (result.balanceChanges) {\n for (const change of result.balanceChanges) {\n if (\n change.coinType === SUPPORTED_ASSETS.SUI.type &&\n change.owner &&\n typeof change.owner === 'object' &&\n 'AddressOwner' in change.owner &&\n change.owner.AddressOwner === address\n ) {\n suiReceived += Number(change.amount) / Number(MIST_PER_SUI);\n }\n }\n }\n\n reportGasUsage(address, result.digest, 0, 0, 'auto-topup');\n\n return {\n success: true,\n tx: result.digest,\n usdcSpent: topupAmountHuman,\n suiReceived: Math.abs(suiReceived),\n };\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type { Ed25519Keypair } from '@mysten/sui/keypairs/ed25519';\nimport { Transaction } from '@mysten/sui/transactions';\nimport {\n SUPPORTED_ASSETS,\n AUTO_TOPUP_THRESHOLD,\n MIST_PER_SUI,\n} from '../constants.js';\nimport type { GasMethod } from '../types.js';\nimport { T2000Error } from '../errors.js';\nimport { shouldAutoTopUp, executeAutoTopUp } from './autoTopUp.js';\nimport { requestGasSponsorship, reportGasUsage } from './gasStation.js';\n\nexport interface GasExecutionResult {\n digest: string;\n effects: unknown;\n gasMethod: GasMethod;\n gasCostSui: number;\n}\n\nfunction extractGasCost(\n effects: { gasUsed?: { computationCost: string; storageCost: string; storageRebate: string } } | undefined | null,\n): number {\n if (!effects?.gasUsed) return 0;\n return (\n Number(effects.gasUsed.computationCost) +\n Number(effects.gasUsed.storageCost) -\n Number(effects.gasUsed.storageRebate)\n ) / 1e9;\n}\n\nasync function getSuiBalance(client: SuiJsonRpcClient, address: string): Promise<bigint> {\n const bal = await client.getBalance({ owner: address, coinType: SUPPORTED_ASSETS.SUI.type });\n return BigInt(bal.totalBalance);\n}\n\nasync function trySelfFunded(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n tx: Transaction,\n): Promise<GasExecutionResult | null> {\n const address = keypair.getPublicKey().toSuiAddress();\n const suiBalance = await getSuiBalance(client, address);\n\n // Need at least 0.05 SUI for gas\n if (suiBalance < AUTO_TOPUP_THRESHOLD) return null;\n\n tx.setSender(address);\n\n const result = await client.signAndExecuteTransaction({\n signer: keypair,\n transaction: tx,\n options: { showEffects: true },\n });\n await client.waitForTransaction({ digest: result.digest });\n\n return {\n digest: result.digest,\n effects: result.effects,\n gasMethod: 'self-funded',\n gasCostSui: extractGasCost(result.effects as Parameters<typeof extractGasCost>[0]),\n };\n}\n\nasync function tryAutoTopUpThenSelfFund(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n tx: Transaction,\n): Promise<GasExecutionResult | null> {\n const address = keypair.getPublicKey().toSuiAddress();\n\n const canTopUp = await shouldAutoTopUp(client, address);\n if (!canTopUp) return null;\n\n // Let errors propagate so executeWithGas captures the real reason\n await executeAutoTopUp(client, keypair);\n\n // After top-up, try self-funded again\n tx.setSender(address);\n\n const result = await client.signAndExecuteTransaction({\n signer: keypair,\n transaction: tx,\n options: { showEffects: true },\n });\n await client.waitForTransaction({ digest: result.digest });\n\n return {\n digest: result.digest,\n effects: result.effects,\n gasMethod: 'auto-topup',\n gasCostSui: extractGasCost(result.effects as Parameters<typeof extractGasCost>[0]),\n };\n}\n\nasync function trySponsored(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n tx: Transaction,\n): Promise<GasExecutionResult | null> {\n const address = keypair.getPublicKey().toSuiAddress();\n tx.setSender(address);\n\n const txJson = tx.serialize();\n const sponsoredResult = await requestGasSponsorship(txJson, address);\n\n const sponsoredTxBytes = Buffer.from(sponsoredResult.txBytes, 'base64');\n const { signature: agentSig } = await keypair.signTransaction(sponsoredTxBytes);\n\n const result = await client.executeTransactionBlock({\n transactionBlock: sponsoredResult.txBytes,\n signature: [agentSig, sponsoredResult.sponsorSignature],\n options: { showEffects: true },\n });\n\n await client.waitForTransaction({ digest: result.digest });\n\n // Report gas usage (best-effort)\n const gasCost = extractGasCost(result.effects as Parameters<typeof extractGasCost>[0]);\n reportGasUsage(address, result.digest, gasCost, 0, sponsoredResult.type);\n\n return {\n digest: result.digest,\n effects: result.effects,\n gasMethod: 'sponsored',\n gasCostSui: gasCost,\n };\n}\n\n/**\n * Gas resolution chain:\n * 1. Self-funded (agent has enough SUI)\n * 2. Auto-topup (swap USDC→SUI, then self-fund)\n * 3. Gas Station sponsored (fallback)\n * 4. Fail with INSUFFICIENT_GAS\n */\nexport async function executeWithGas(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n buildTx: () => Transaction | Promise<Transaction>,\n): Promise<GasExecutionResult> {\n const errors: string[] = [];\n\n // Step 1: Try self-funded\n try {\n const tx = await buildTx();\n const result = await trySelfFunded(client, keypair, tx);\n if (result) return result;\n errors.push('self-funded: SUI below threshold');\n } catch (err) {\n errors.push(`self-funded: ${err instanceof Error ? err.message : String(err)}`);\n }\n\n // Step 2: Try auto-topup then self-fund\n try {\n const tx = await buildTx();\n const result = await tryAutoTopUpThenSelfFund(client, keypair, tx);\n if (result) return result;\n errors.push('auto-topup: not eligible (low USDC or sufficient SUI)');\n } catch (err) {\n errors.push(`auto-topup: ${err instanceof Error ? err.message : String(err)}`);\n }\n\n // Step 3: Try gas station sponsored\n try {\n const tx = await buildTx();\n const result = await trySponsored(client, keypair, tx);\n if (result) return result;\n errors.push('sponsored: returned null');\n } catch (err) {\n errors.push(`sponsored: ${err instanceof Error ? err.message : String(err)}`);\n }\n\n // Step 4: All methods failed\n throw new T2000Error(\n 'INSUFFICIENT_GAS',\n `No SUI for gas and Gas Station unavailable. Fund your wallet with SUI or USDC. [${errors.join(' | ')}]`,\n { reason: 'all_gas_methods_exhausted', errors },\n );\n}\n","import { EventEmitter } from 'eventemitter3';\nimport type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type { Ed25519Keypair } from '@mysten/sui/keypairs/ed25519';\nimport { getSuiClient } from './utils/sui.js';\nimport {\n generateKeypair,\n keypairFromPrivateKey,\n saveKey,\n loadKey,\n walletExists,\n exportPrivateKey,\n getAddress,\n} from './wallet/keyManager.js';\nimport { buildSendTx } from './wallet/send.js';\nimport { queryBalance } from './wallet/balance.js';\nimport { queryHistory } from './wallet/history.js';\nimport { calculateFee, reportFee } from './protocols/protocolFee.js';\nimport * as yieldTracker from './protocols/yieldTracker.js';\nimport * as sentinel from './protocols/sentinel.js';\nimport { ProtocolRegistry } from './adapters/registry.js';\nimport { NaviAdapter } from './adapters/navi.js';\nimport { CetusAdapter } from './adapters/cetus.js';\nimport { SuilendAdapter } from './adapters/suilend.js';\nimport type { LendingAdapter, SwapAdapter } from './adapters/types.js';\nimport { solveHashcash } from './utils/hashcash.js';\nimport { executeWithGas } from './gas/manager.js';\nimport type {\n T2000Options,\n BalanceResponse,\n SendResult,\n SaveResult,\n WithdrawResult,\n BorrowResult,\n RepayResult,\n SwapResult,\n HealthFactorResult,\n MaxWithdrawResult,\n MaxBorrowResult,\n RatesResult,\n PositionsResult,\n TransactionRecord,\n DepositInfo,\n EarningsResult,\n FundStatusResult,\n SentinelAgent,\n SentinelAttackResult,\n} from './types.js';\nimport { T2000Error } from './errors.js';\nimport { SUPPORTED_ASSETS, DEFAULT_NETWORK, API_BASE_URL } from './constants.js';\nimport { truncateAddress } from './utils/sui.js';\n\ninterface T2000Events {\n balanceChange: (event: { asset: string; previous: number; current: number; cause: string; tx?: string }) => void;\n healthWarning: (event: { healthFactor: number; threshold: number; severity: 'warning' }) => void;\n healthCritical: (event: { healthFactor: number; threshold: number; severity: 'critical' }) => void;\n yield: (event: { earned: number; total: number; apy: number; timestamp: number }) => void;\n gasAutoTopUp: (result: { usdcSpent: number; suiReceived: number }) => void;\n gasStationFallback: (event: { reason: string; method: string; suiUsed: number }) => void;\n error: (error: T2000Error) => void;\n}\n\nexport class T2000 extends EventEmitter<T2000Events> {\n private readonly keypair: Ed25519Keypair;\n private readonly client: SuiJsonRpcClient;\n private readonly _address: string;\n private readonly registry: ProtocolRegistry;\n\n private constructor(keypair: Ed25519Keypair, client: SuiJsonRpcClient, registry?: ProtocolRegistry) {\n super();\n this.keypair = keypair;\n this.client = client;\n this._address = getAddress(keypair);\n this.registry = registry ?? T2000.createDefaultRegistry(client);\n }\n\n private static createDefaultRegistry(client: SuiJsonRpcClient): ProtocolRegistry {\n const registry = new ProtocolRegistry();\n const naviAdapter = new NaviAdapter();\n naviAdapter.initSync(client);\n registry.registerLending(naviAdapter);\n const cetusAdapter = new CetusAdapter();\n cetusAdapter.initSync(client);\n registry.registerSwap(cetusAdapter);\n const suilendAdapter = new SuilendAdapter();\n suilendAdapter.initSync(client);\n registry.registerLending(suilendAdapter);\n return registry;\n }\n\n static async create(options: T2000Options = {}): Promise<T2000> {\n const { keyPath, pin, passphrase, network = DEFAULT_NETWORK, rpcUrl, sponsored, name } = options;\n const secret = pin ?? passphrase;\n\n const client = getSuiClient(rpcUrl);\n\n if (sponsored) {\n const keypair = generateKeypair();\n if (secret) {\n await saveKey(keypair, secret, keyPath);\n }\n return new T2000(keypair, client);\n }\n\n const exists = await walletExists(keyPath);\n if (!exists) {\n throw new T2000Error(\n 'WALLET_NOT_FOUND',\n 'No wallet found. Run `t2000 init` to create one.',\n );\n }\n\n if (!secret) {\n throw new T2000Error('WALLET_LOCKED', 'PIN required to unlock wallet');\n }\n\n const keypair = await loadKey(secret, keyPath);\n return new T2000(keypair, client);\n }\n\n static fromPrivateKey(privateKey: string, options: { network?: 'mainnet' | 'testnet'; rpcUrl?: string } = {}): T2000 {\n const keypair = keypairFromPrivateKey(privateKey);\n const client = getSuiClient(options.rpcUrl);\n return new T2000(keypair, client);\n }\n\n static async init(options: { pin: string; passphrase?: string; keyPath?: string; name?: string; sponsored?: boolean }): Promise<{ agent: T2000; address: string; sponsored: boolean }> {\n const secret = options.pin ?? options.passphrase ?? '';\n const keypair = generateKeypair();\n await saveKey(keypair, secret, options.keyPath);\n\n const client = getSuiClient();\n const agent = new T2000(keypair, client);\n const address = agent.address();\n\n let sponsored = false;\n if (options.sponsored !== false) {\n try {\n await callSponsorApi(address, options.name);\n sponsored = true;\n } catch {\n // Sponsor unavailable — agent can still be funded manually\n }\n }\n\n return { agent, address, sponsored };\n }\n\n // -- Gas --\n\n /** SuiJsonRpcClient used by this agent — exposed for x402 and other integrations. */\n get suiClient(): SuiJsonRpcClient {\n return this.client;\n }\n\n /** Ed25519Keypair used by this agent — exposed for x402 and other integrations. */\n get signer(): Ed25519Keypair {\n return this.keypair;\n }\n\n // -- Wallet --\n\n address(): string {\n return this._address;\n }\n\n async send(params: { to: string; amount: number; asset?: string }): Promise<SendResult> {\n const asset = (params.asset ?? 'USDC') as keyof typeof SUPPORTED_ASSETS;\n if (!(asset in SUPPORTED_ASSETS)) {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `Asset ${asset} is not supported`);\n }\n\n const sendAmount = params.amount;\n const sendTo = params.to;\n\n const gasResult = await executeWithGas(this.client, this.keypair, () =>\n buildSendTx({ client: this.client, address: this._address, to: sendTo, amount: sendAmount, asset }),\n );\n\n const balance = await this.balance();\n\n this.emitBalanceChange(asset, sendAmount, 'send', gasResult.digest);\n\n return {\n success: true,\n tx: gasResult.digest,\n amount: sendAmount,\n to: params.to,\n gasCost: gasResult.gasCostSui,\n gasCostUnit: 'SUI',\n gasMethod: gasResult.gasMethod,\n balance,\n };\n }\n\n async balance(): Promise<BalanceResponse> {\n const bal = await queryBalance(this.client, this._address);\n\n try {\n const positions = await this.positions();\n const savings = positions.positions\n .filter((p) => p.type === 'save')\n .reduce((sum, p) => sum + p.amount, 0);\n bal.savings = savings;\n bal.total = bal.available + savings + bal.gasReserve.usdEquiv;\n } catch {\n // NAVI unavailable — show basic balance\n }\n\n return bal;\n }\n\n async history(params?: { limit?: number }): Promise<TransactionRecord[]> {\n return queryHistory(this.client, this._address, params?.limit);\n }\n\n async deposit(): Promise<DepositInfo> {\n return {\n address: this._address,\n network: 'Sui (mainnet)',\n supportedAssets: ['USDC'],\n instructions: [\n `Send USDC on Sui to: ${this._address}`,\n '',\n 'From a CEX (Coinbase, Binance):',\n ` 1. Withdraw USDC`,\n ` 2. Select \"Sui\" network`,\n ` 3. Paste address: ${truncateAddress(this._address)}`,\n '',\n 'From another Sui wallet:',\n ` Transfer USDC to ${truncateAddress(this._address)}`,\n ].join('\\n'),\n };\n }\n\n exportKey(): string {\n return exportPrivateKey(this.keypair);\n }\n\n async registerAdapter(adapter: LendingAdapter | SwapAdapter): Promise<void> {\n await adapter.init(this.client);\n if ('buildSaveTx' in adapter) this.registry.registerLending(adapter as LendingAdapter);\n if ('buildSwapTx' in adapter) this.registry.registerSwap(adapter as SwapAdapter);\n }\n\n // -- Savings --\n\n async save(params: { amount: number | 'all'; asset?: string; protocol?: string }): Promise<SaveResult> {\n const asset = (params.asset ?? 'USDC').toUpperCase();\n if (asset !== 'USDC') {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `Only USDC is supported for save. Got: ${asset}`);\n }\n\n let amount: number;\n if (params.amount === 'all') {\n const bal = await queryBalance(this.client, this._address);\n const GAS_RESERVE_USDC = 1.0;\n amount = bal.available - GAS_RESERVE_USDC;\n if (amount <= 0) {\n throw new T2000Error('INSUFFICIENT_BALANCE', 'Balance too low to save after $1 gas reserve', {\n reason: 'gas_reserve_required',\n available: bal.available,\n });\n }\n } else {\n amount = params.amount;\n }\n const fee = calculateFee('save', amount);\n const saveAmount = amount;\n\n const adapter = await this.resolveLending(params.protocol, asset, 'save');\n\n const gasResult = await executeWithGas(this.client, this.keypair, async () => {\n const { tx } = await adapter.buildSaveTx(this._address, saveAmount, asset, { collectFee: true });\n return tx;\n });\n\n const rates = await adapter.getRates(asset);\n reportFee(this._address, 'save', fee.amount, fee.rate, gasResult.digest);\n this.emitBalanceChange('USDC', saveAmount, 'save', gasResult.digest);\n\n let savingsBalance = saveAmount;\n try {\n const positions = await this.positions();\n savingsBalance = positions.positions\n .filter((p) => p.type === 'save')\n .reduce((sum, p) => sum + p.amount, 0);\n } catch {\n // query failed — fall back to deposit amount\n }\n\n return {\n success: true,\n tx: gasResult.digest,\n amount: saveAmount,\n apy: rates.saveApy,\n fee: fee.amount,\n gasCost: gasResult.gasCostSui,\n gasMethod: gasResult.gasMethod,\n savingsBalance,\n };\n }\n\n async withdraw(params: { amount: number | 'all'; asset?: string; protocol?: string }): Promise<WithdrawResult> {\n const asset = (params.asset ?? 'USDC').toUpperCase();\n if (asset !== 'USDC') {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `Only USDC is supported for withdraw. Got: ${asset}`);\n }\n\n const adapter = await this.resolveLending(params.protocol, asset, 'withdraw');\n\n let amount: number;\n if (params.amount === 'all') {\n const maxResult = await adapter.maxWithdraw(this._address, asset);\n amount = maxResult.maxAmount;\n if (amount <= 0) {\n throw new T2000Error('NO_COLLATERAL', 'No savings to withdraw');\n }\n } else {\n amount = params.amount;\n\n const hf = await adapter.getHealth(this._address);\n if (hf.borrowed > 0) {\n const maxResult = await adapter.maxWithdraw(this._address, asset);\n if (amount > maxResult.maxAmount) {\n throw new T2000Error(\n 'WITHDRAW_WOULD_LIQUIDATE',\n `Withdrawing $${amount.toFixed(2)} would drop health factor below 1.5`,\n {\n safeWithdrawAmount: maxResult.maxAmount,\n currentHF: maxResult.currentHF,\n projectedHF: maxResult.healthFactorAfter,\n },\n );\n }\n }\n }\n const withdrawAmount = amount;\n let effectiveAmount = withdrawAmount;\n\n const gasResult = await executeWithGas(this.client, this.keypair, async () => {\n const built = await adapter.buildWithdrawTx(this._address, withdrawAmount, asset);\n effectiveAmount = built.effectiveAmount;\n return built.tx;\n });\n\n this.emitBalanceChange('USDC', effectiveAmount, 'withdraw', gasResult.digest);\n\n return {\n success: true,\n tx: gasResult.digest,\n amount: effectiveAmount,\n gasCost: gasResult.gasCostSui,\n gasMethod: gasResult.gasMethod,\n };\n }\n\n async maxWithdraw(): Promise<MaxWithdrawResult> {\n const adapter = await this.resolveLending(undefined, 'USDC', 'withdraw');\n return adapter.maxWithdraw(this._address, 'USDC');\n }\n\n // -- Borrowing --\n\n async borrow(params: { amount: number; asset?: string; protocol?: string }): Promise<BorrowResult> {\n const asset = (params.asset ?? 'USDC').toUpperCase();\n if (asset !== 'USDC') {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `Only USDC is supported for borrow. Got: ${asset}`);\n }\n\n const adapter = await this.resolveLending(params.protocol, asset, 'borrow');\n\n const maxResult = await adapter.maxBorrow(this._address, asset);\n if (params.amount > maxResult.maxAmount) {\n throw new T2000Error('HEALTH_FACTOR_TOO_LOW', `Max safe borrow: $${maxResult.maxAmount.toFixed(2)}`, {\n maxBorrow: maxResult.maxAmount,\n currentHF: maxResult.currentHF,\n });\n }\n const fee = calculateFee('borrow', params.amount);\n const borrowAmount = params.amount;\n\n const gasResult = await executeWithGas(this.client, this.keypair, async () => {\n const { tx } = await adapter.buildBorrowTx(this._address, borrowAmount, asset, { collectFee: true });\n return tx;\n });\n\n const hf = await adapter.getHealth(this._address);\n reportFee(this._address, 'borrow', fee.amount, fee.rate, gasResult.digest);\n this.emitBalanceChange('USDC', borrowAmount, 'borrow', gasResult.digest);\n\n return {\n success: true,\n tx: gasResult.digest,\n amount: borrowAmount,\n fee: fee.amount,\n healthFactor: hf.healthFactor,\n gasCost: gasResult.gasCostSui,\n gasMethod: gasResult.gasMethod,\n };\n }\n\n async repay(params: { amount: number | 'all'; asset?: string; protocol?: string }): Promise<RepayResult> {\n const asset = (params.asset ?? 'USDC').toUpperCase();\n if (asset !== 'USDC') {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `Only USDC is supported for repay. Got: ${asset}`);\n }\n\n const adapter = await this.resolveLending(params.protocol, asset, 'repay');\n\n let amount: number;\n if (params.amount === 'all') {\n const hf = await adapter.getHealth(this._address);\n amount = hf.borrowed;\n if (amount <= 0) {\n throw new T2000Error('NO_COLLATERAL', 'No outstanding borrow to repay');\n }\n } else {\n amount = params.amount;\n }\n const repayAmount = amount;\n\n const gasResult = await executeWithGas(this.client, this.keypair, async () => {\n const { tx } = await adapter.buildRepayTx(this._address, repayAmount, asset);\n return tx;\n });\n\n const hf = await adapter.getHealth(this._address);\n this.emitBalanceChange('USDC', repayAmount, 'repay', gasResult.digest);\n\n return {\n success: true,\n tx: gasResult.digest,\n amount: repayAmount,\n remainingDebt: hf.borrowed,\n gasCost: gasResult.gasCostSui,\n gasMethod: gasResult.gasMethod,\n };\n }\n\n async maxBorrow(): Promise<MaxBorrowResult> {\n const adapter = await this.resolveLending(undefined, 'USDC', 'borrow');\n return adapter.maxBorrow(this._address, 'USDC');\n }\n\n async healthFactor(): Promise<HealthFactorResult> {\n const adapter = await this.resolveLending(undefined, 'USDC', 'save');\n const hf = await adapter.getHealth(this._address);\n\n if (hf.healthFactor < 1.2) {\n this.emit('healthCritical', { healthFactor: hf.healthFactor, threshold: 1.5, severity: 'critical' });\n } else if (hf.healthFactor < 2.0) {\n this.emit('healthWarning', { healthFactor: hf.healthFactor, threshold: 2.0, severity: 'warning' });\n }\n\n return hf;\n }\n\n // -- Swap --\n\n async swap(params: { from: string; to: string; amount: number; maxSlippage?: number; protocol?: string }): Promise<SwapResult> {\n const fromAsset = params.from.toUpperCase() as 'USDC' | 'SUI';\n const toAsset = params.to.toUpperCase() as 'USDC' | 'SUI';\n\n if (!(fromAsset in SUPPORTED_ASSETS) || !(toAsset in SUPPORTED_ASSETS)) {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `Swap pair ${fromAsset}/${toAsset} is not supported`);\n }\n if (fromAsset === toAsset) {\n throw new T2000Error('INVALID_AMOUNT', 'Cannot swap same asset');\n }\n\n let adapter: SwapAdapter;\n if (params.protocol) {\n const found = this.registry.getSwap(params.protocol);\n if (!found) throw new T2000Error('ASSET_NOT_SUPPORTED', `Swap adapter '${params.protocol}' not found`);\n adapter = found;\n } else {\n const best = await this.registry.bestSwapQuote(fromAsset, toAsset, params.amount);\n adapter = best.adapter;\n }\n\n const fee = calculateFee('swap', params.amount);\n const swapAmount = params.amount;\n const slippageBps = params.maxSlippage ? params.maxSlippage * 100 : undefined;\n\n let swapMeta: { estimatedOut: number; toDecimals: number } = { estimatedOut: 0, toDecimals: 0 };\n\n const gasResult = await executeWithGas(this.client, this.keypair, async () => {\n const built = await adapter.buildSwapTx(this._address, fromAsset, toAsset, swapAmount, slippageBps);\n swapMeta = { estimatedOut: built.estimatedOut, toDecimals: built.toDecimals };\n return built.tx;\n });\n\n const toInfo = SUPPORTED_ASSETS[toAsset];\n await this.client.waitForTransaction({ digest: gasResult.digest });\n const txDetail = await this.client.getTransactionBlock({\n digest: gasResult.digest,\n options: { showBalanceChanges: true },\n });\n\n let actualReceived = 0;\n if (txDetail.balanceChanges) {\n for (const change of txDetail.balanceChanges) {\n if (\n change.coinType === toInfo.type &&\n change.owner &&\n typeof change.owner === 'object' &&\n 'AddressOwner' in change.owner &&\n change.owner.AddressOwner === this._address\n ) {\n const amt = Number(change.amount) / 10 ** toInfo.decimals;\n if (amt > 0) actualReceived += amt;\n }\n }\n }\n\n const expectedOutput = swapMeta.estimatedOut / 10 ** swapMeta.toDecimals;\n if (actualReceived === 0) actualReceived = expectedOutput;\n\n const priceImpact = expectedOutput > 0\n ? Math.abs(actualReceived - expectedOutput) / expectedOutput\n : 0;\n\n reportFee(this._address, 'swap', fee.amount, fee.rate, gasResult.digest);\n this.emitBalanceChange(fromAsset, swapAmount, 'swap', gasResult.digest);\n\n return {\n success: true,\n tx: gasResult.digest,\n fromAmount: swapAmount,\n fromAsset,\n toAmount: actualReceived,\n toAsset,\n priceImpact,\n fee: fee.amount,\n gasCost: gasResult.gasCostSui,\n gasMethod: gasResult.gasMethod,\n };\n }\n\n async swapQuote(params: { from: string; to: string; amount: number }): Promise<{\n expectedOutput: number;\n priceImpact: number;\n poolPrice: number;\n fee: { amount: number; rate: number };\n }> {\n const fromAsset = params.from.toUpperCase();\n const toAsset = params.to.toUpperCase();\n const best = await this.registry.bestSwapQuote(fromAsset, toAsset, params.amount);\n const fee = calculateFee('swap', params.amount);\n return { ...best.quote, fee: { amount: fee.amount, rate: fee.rate } };\n }\n\n // -- Info --\n\n async positions(): Promise<PositionsResult> {\n const allPositions = await this.registry.allPositions(this._address);\n const positions = allPositions.flatMap(p =>\n [\n ...p.positions.supplies.map(s => ({\n protocol: p.protocolId,\n asset: s.asset,\n type: 'save' as const,\n amount: s.amount,\n apy: s.apy,\n })),\n ...p.positions.borrows.map(b => ({\n protocol: p.protocolId,\n asset: b.asset,\n type: 'borrow' as const,\n amount: b.amount,\n apy: b.apy,\n })),\n ],\n );\n return { positions };\n }\n\n async rates(): Promise<RatesResult> {\n const allRatesResult = await this.registry.allRates('USDC');\n if (allRatesResult.length === 0) return { USDC: { saveApy: 0, borrowApy: 0 } };\n const best = allRatesResult.reduce((a, b) => (b.rates.saveApy > a.rates.saveApy ? b : a));\n return { USDC: { saveApy: best.rates.saveApy, borrowApy: best.rates.borrowApy } };\n }\n\n async allRates(asset = 'USDC') {\n return this.registry.allRates(asset);\n }\n\n async earnings(): Promise<EarningsResult> {\n const result = await yieldTracker.getEarnings(this.client, this.keypair);\n\n if (result.totalYieldEarned > 0) {\n this.emit('yield', {\n earned: result.dailyEarning,\n total: result.totalYieldEarned,\n apy: result.currentApy / 100,\n timestamp: Date.now(),\n });\n }\n\n return result;\n }\n\n async fundStatus(): Promise<FundStatusResult> {\n return yieldTracker.getFundStatus(this.client, this.keypair);\n }\n\n // -- Sentinel --\n\n async sentinelList(): Promise<SentinelAgent[]> {\n return sentinel.listSentinels();\n }\n\n async sentinelInfo(id: string): Promise<SentinelAgent> {\n return sentinel.getSentinelInfo(this.client, id);\n }\n\n async sentinelAttack(id: string, prompt: string, fee?: bigint): Promise<SentinelAttackResult> {\n return sentinel.attack(this.client, this.keypair, id, prompt, fee);\n }\n\n // -- Helpers --\n\n private async resolveLending(protocol: string | undefined, asset: string, capability: 'save' | 'withdraw' | 'borrow' | 'repay'): Promise<LendingAdapter> {\n if (protocol) {\n const adapter = this.registry.getLending(protocol);\n if (!adapter) throw new T2000Error('ASSET_NOT_SUPPORTED', `Lending adapter '${protocol}' not found`);\n return adapter;\n }\n\n if (capability === 'save') {\n const { adapter } = await this.registry.bestSaveRate(asset);\n return adapter;\n }\n\n if (capability === 'borrow' || capability === 'repay') {\n const adapters = this.registry.listLending().filter(\n a => a.supportedAssets.includes(asset) &&\n a.capabilities.includes(capability) &&\n (capability !== 'borrow' || a.supportsSameAssetBorrow),\n );\n if (adapters.length === 0) throw new T2000Error('ASSET_NOT_SUPPORTED', `No adapter supports ${capability} ${asset}`);\n return adapters[0];\n }\n\n const adapters = this.registry.listLending().filter(\n a => a.supportedAssets.includes(asset) && a.capabilities.includes(capability),\n );\n if (adapters.length === 0) throw new T2000Error('ASSET_NOT_SUPPORTED', `No adapter supports ${capability} ${asset}`);\n return adapters[0];\n }\n\n private emitBalanceChange(asset: string, amount: number, cause: string, tx?: string): void {\n this.emit('balanceChange', { asset, previous: 0, current: 0, cause, tx });\n }\n}\n\nasync function callSponsorApi(address: string, name?: string): Promise<void> {\n const res = await fetch(`${API_BASE_URL}/api/sponsor`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ address, name }),\n });\n\n if (res.status === 429) {\n const data = await res.json() as { challenge?: string };\n if (data.challenge) {\n const proof = solveHashcash(data.challenge);\n const retry = await fetch(`${API_BASE_URL}/api/sponsor`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ address, name, proof }),\n });\n if (!retry.ok) throw new T2000Error('SPONSOR_RATE_LIMITED', 'Sponsor rate limited');\n return;\n }\n }\n\n if (!res.ok) {\n throw new T2000Error('SPONSOR_FAILED', 'Sponsor API unavailable');\n }\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport { Transaction } from '@mysten/sui/transactions';\nimport { T2000Error } from '../errors.js';\nimport { mapMoveAbortCode } from '../errors.js';\n\nexport interface SimulationResult {\n success: boolean;\n gasEstimateSui: number;\n error?: {\n moveAbortCode?: number;\n moveModule?: string;\n reason: string;\n rawError: string;\n };\n}\n\nexport async function simulateTransaction(\n client: SuiJsonRpcClient,\n tx: Transaction,\n sender: string,\n): Promise<SimulationResult> {\n tx.setSender(sender);\n\n try {\n const txBytes = await tx.build({ client });\n const dryRun = await client.dryRunTransactionBlock({\n transactionBlock: Buffer.from(txBytes).toString('base64'),\n });\n\n const status = dryRun.effects?.status;\n const gasUsed = dryRun.effects?.gasUsed;\n\n const gasEstimateSui = gasUsed\n ? (Number(gasUsed.computationCost) +\n Number(gasUsed.storageCost) -\n Number(gasUsed.storageRebate)) / 1e9\n : 0;\n\n if (status?.status === 'failure') {\n const rawError = status.error ?? 'Unknown simulation error';\n const parsed = parseMoveAbort(rawError);\n\n return {\n success: false,\n gasEstimateSui,\n error: {\n moveAbortCode: parsed.abortCode,\n moveModule: parsed.module,\n reason: parsed.reason,\n rawError,\n },\n };\n }\n\n return { success: true, gasEstimateSui };\n } catch (err) {\n const rawError = err instanceof Error ? err.message : String(err);\n return {\n success: false,\n gasEstimateSui: 0,\n error: {\n reason: 'Simulation failed: ' + rawError,\n rawError,\n },\n };\n }\n}\n\nexport function throwIfSimulationFailed(sim: SimulationResult): void {\n if (sim.success) return;\n\n throw new T2000Error(\n 'SIMULATION_FAILED',\n sim.error?.reason ?? 'Transaction simulation failed',\n {\n moveAbortCode: sim.error?.moveAbortCode,\n moveModule: sim.error?.moveModule,\n reason: sim.error?.reason,\n rawError: sim.error?.rawError,\n },\n );\n}\n\nfunction parseMoveAbort(errorStr: string): {\n abortCode?: number;\n module?: string;\n reason: string;\n} {\n // Pattern: MoveAbort(MoveLocation { module: ModuleId { ... name: \"module\" }, ... }, code)\n const abortMatch = errorStr.match(/MoveAbort\\([^,]*,\\s*(\\d+)\\)/);\n const moduleMatch = errorStr.match(/name:\\s*Identifier\\(\"([^\"]+)\"\\)/);\n\n if (abortMatch) {\n const code = parseInt(abortMatch[1], 10);\n const module = moduleMatch?.[1];\n const reason = mapMoveAbortCode(code);\n return { abortCode: code, module, reason };\n }\n\n // Pattern: MovePrimitiveRuntimeError\n if (errorStr.includes('MovePrimitiveRuntimeError')) {\n const module = moduleMatch?.[1];\n return {\n module,\n reason: `Move runtime error in ${module ?? 'unknown'} module`,\n };\n }\n\n return { reason: errorStr };\n}\n"]}
1
+ {"version":3,"sources":["../src/constants.ts","../src/errors.ts","../src/utils/sui.ts","../src/wallet/keyManager.ts","../src/utils/format.ts","../src/wallet/send.ts","../src/wallet/balance.ts","../src/wallet/history.ts","../src/protocols/protocolFee.ts","../src/protocols/navi.ts","../src/protocols/yieldTracker.ts","../src/protocols/sentinel.ts","../src/adapters/registry.ts","../src/adapters/navi.ts","../src/protocols/cetus.ts","../src/adapters/cetus.ts","../src/adapters/suilend.ts","../src/utils/hashcash.ts","../src/gas/gasStation.ts","../src/gas/autoTopUp.ts","../src/gas/manager.ts","../src/t2000.ts","../src/utils/simulate.ts","../src/adapters/index.ts"],"names":["SuiJsonRpcClient","normalizeSuiAddress","isValidSuiAddress","resolve","homedir","scryptSync","randomBytes","createCipheriv","createDecipheriv","Ed25519Keypair","decodeSuiPrivateKey","access","mkdir","dirname","writeFile","readFile","Transaction","bcs","f","attack","descriptor","AggregatorClient","Env","USDC_TYPE","MIN_HEALTH_FACTOR","CLOCK","normalizeStructTag","createHash","EventEmitter","keypair","hf","adapters"],"mappings":"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","file":"index.cjs","sourcesContent":["export const MIST_PER_SUI = 1_000_000_000n;\nexport const SUI_DECIMALS = 9;\nexport const USDC_DECIMALS = 6;\n\nexport const BPS_DENOMINATOR = 10_000n;\nexport const PRECISION = 1_000_000_000_000_000_000n;\n\nexport const MIN_DEPOSIT = 1_000_000n; // 1 USDC (6 decimals)\nexport const GAS_RESERVE_USDC = 1_000_000n; // $1 USDC reserved for gas\nexport const AUTO_TOPUP_THRESHOLD = 50_000_000n; // 0.05 SUI\nexport const AUTO_TOPUP_AMOUNT = 1_000_000n; // $1 USDC worth of SUI\nexport const AUTO_TOPUP_MIN_USDC = 2_000_000n; // $2 USDC minimum to trigger auto-topup\nexport const BOOTSTRAP_LIMIT = 10;\nexport const GAS_FEE_CEILING_USD = 0.05;\n\nexport const SAVE_FEE_BPS = 10n; // 0.1%\nexport const SWAP_FEE_BPS = 0n; // Free — Cetus already charges pool fees\nexport const BORROW_FEE_BPS = 5n; // 0.05%\n\nexport const CLOCK_ID = '0x6';\n\nexport const SUPPORTED_ASSETS = {\n USDC: {\n type: '0xdba34672e30cb065b1f93e3ab55318768fd6fef66c15942c9f7cb846e2f900e7::usdc::USDC',\n decimals: 6,\n symbol: 'USDC',\n },\n SUI: {\n type: '0x2::sui::SUI',\n decimals: 9,\n symbol: 'SUI',\n },\n} as const;\n\nexport type SupportedAsset = keyof typeof SUPPORTED_ASSETS;\n\nexport const T2000_PACKAGE_ID = process.env.T2000_PACKAGE_ID ?? '0xab92e9f1fe549ad3d6a52924a73181b45791e76120b975138fac9ec9b75db9f3';\nexport const T2000_CONFIG_ID = process.env.T2000_CONFIG_ID ?? '0x408add9aa9322f93cfd87523d8f603006eb8713894f4c460283c58a6888dae8a';\nexport const T2000_ADMIN_CAP_ID = '0x863d1b02cba1b93d0fe9b87eb92d58b60c1e85c001022cb2a760e07bade47e65';\nexport const T2000_UPGRADE_CAP_ID = '0xef28746d40f43ca6be1352102cef0152133bf5594e69caab28f40b1de74490c1';\nexport const T2000_TREASURY_ID = process.env.T2000_TREASURY_ID ?? '0x3bb501b8300125dca59019247941a42af6b292a150ce3cfcce9449456be2ec91';\n\nexport const DEFAULT_NETWORK = 'mainnet' as const;\nexport const DEFAULT_RPC_URL = 'https://fullnode.mainnet.sui.io:443';\nexport const DEFAULT_KEY_PATH = '~/.t2000/wallet.key';\nexport const DEFAULT_CONFIG_PATH = '~/.t2000/config.json';\n\nexport const API_BASE_URL = process.env.T2000_API_URL ?? 'https://api.t2000.ai';\n\nexport const CETUS_USDC_SUI_POOL = '0x51e883ba7c0b566a26cbc8a94cd33eb0abd418a77cc1e60ad22fd9b1f29cd2ab';\nexport const CETUS_GLOBAL_CONFIG = '0xdaa46292632c3c4d8f31f23ea0f9b36a28ff3677e9684980e4438403a67a3d8f';\nexport const CETUS_PACKAGE = '0x1eabed72c53feb3805120a081dc15963c204dc8d091542592abaf7a35689b2fb';\n\nexport const SENTINEL = {\n PACKAGE: '0x88b83f36dafcd5f6dcdcf1d2cb5889b03f61264ab3cee9cae35db7aa940a21b7',\n AGENT_REGISTRY: '0xc47564f5f14c12b31e0dfa1a3dc99a6380a1edf8929c28cb0eaa3359c8db36ac',\n ENCLAVE: '0xfb1261aeb9583514cb1341a548a5ec12d1231bd96af22215f1792617a93e1213',\n PROTOCOL_CONFIG: '0x2fa4fa4a1dd0498612304635ff9334e1b922e78af325000e9d9c0e88adea459f',\n TEE_API: 'https://app.suisentinel.xyz/api/consume-prompt',\n SENTINELS_API: 'https://api.suisentinel.xyz/agents/mainnet',\n RANDOM: '0x8',\n MIN_FEE_MIST: 100_000_000n, // 0.1 SUI\n MAX_PROMPT_TOKENS: 600,\n} as const;\n","export type T2000ErrorCode =\n | 'INSUFFICIENT_BALANCE'\n | 'INSUFFICIENT_GAS'\n | 'INVALID_ADDRESS'\n | 'INVALID_AMOUNT'\n | 'WALLET_NOT_FOUND'\n | 'WALLET_LOCKED'\n | 'WALLET_EXISTS'\n | 'SPONSOR_FAILED'\n | 'SPONSOR_RATE_LIMITED'\n | 'GAS_STATION_UNAVAILABLE'\n | 'GAS_FEE_EXCEEDED'\n | 'SIMULATION_FAILED'\n | 'TRANSACTION_FAILED'\n | 'ASSET_NOT_SUPPORTED'\n | 'SLIPPAGE_EXCEEDED'\n | 'HEALTH_FACTOR_TOO_LOW'\n | 'WITHDRAW_WOULD_LIQUIDATE'\n | 'NO_COLLATERAL'\n | 'PROTOCOL_PAUSED'\n | 'PROTOCOL_UNAVAILABLE'\n | 'RPC_ERROR'\n | 'RPC_UNREACHABLE'\n | 'SPONSOR_UNAVAILABLE'\n | 'AUTO_TOPUP_FAILED'\n | 'PRICE_EXCEEDS_LIMIT'\n | 'UNSUPPORTED_NETWORK'\n | 'PAYMENT_EXPIRED'\n | 'DUPLICATE_PAYMENT'\n | 'FACILITATOR_REJECTION'\n | 'FACILITATOR_TIMEOUT'\n | 'SENTINEL_API_ERROR'\n | 'SENTINEL_NOT_FOUND'\n | 'SENTINEL_TX_FAILED'\n | 'SENTINEL_TEE_ERROR'\n | 'UNKNOWN';\n\nexport interface T2000ErrorData {\n reason?: string;\n [key: string]: unknown;\n}\n\nexport class T2000Error extends Error {\n readonly code: T2000ErrorCode;\n readonly data?: T2000ErrorData;\n readonly retryable: boolean;\n\n constructor(code: T2000ErrorCode, message: string, data?: T2000ErrorData, retryable = false) {\n super(message);\n this.name = 'T2000Error';\n this.code = code;\n this.data = data;\n this.retryable = retryable;\n }\n\n toJSON() {\n return {\n error: this.code,\n message: this.message,\n ...(this.data && { data: this.data }),\n retryable: this.retryable,\n };\n }\n}\n\nexport function mapWalletError(error: unknown): T2000Error {\n const msg = error instanceof Error ? error.message : String(error);\n\n if (msg.includes('rejected') || msg.includes('cancelled')) {\n return new T2000Error('TRANSACTION_FAILED', 'Transaction cancelled');\n }\n if (msg.includes('Insufficient') || msg.includes('insufficient')) {\n return new T2000Error('INSUFFICIENT_BALANCE', 'Insufficient balance');\n }\n\n return new T2000Error('UNKNOWN', msg, undefined, true);\n}\n\nexport function mapMoveAbortCode(code: number): string {\n const abortMessages: Record<number, string> = {\n 1: 'Protocol is temporarily paused',\n 2: 'Amount must be greater than zero',\n 3: 'Invalid operation type',\n 4: 'Fee rate exceeds maximum',\n 5: 'Insufficient treasury balance',\n 6: 'Not authorized',\n 7: 'Package version mismatch — upgrade required',\n 8: 'Timelock is active — wait for expiry',\n 9: 'No pending change to execute',\n 10: 'Already at current version',\n };\n return abortMessages[code] ?? `Move abort code: ${code}`;\n}\n","import { SuiJsonRpcClient, getJsonRpcFullnodeUrl } from '@mysten/sui/jsonRpc';\nimport { isValidSuiAddress, normalizeSuiAddress } from '@mysten/sui/utils';\nimport { DEFAULT_RPC_URL } from '../constants.js';\nimport { T2000Error } from '../errors.js';\n\nlet cachedClient: SuiJsonRpcClient | null = null;\n\nexport function getSuiClient(rpcUrl?: string): SuiJsonRpcClient {\n const url = rpcUrl ?? DEFAULT_RPC_URL;\n if (cachedClient) return cachedClient;\n cachedClient = new SuiJsonRpcClient({ url, network: 'mainnet' });\n return cachedClient;\n}\n\nexport function createSuiClient(network: 'mainnet' | 'testnet' = 'mainnet'): SuiJsonRpcClient {\n return new SuiJsonRpcClient({ url: getJsonRpcFullnodeUrl(network), network });\n}\n\nexport function validateAddress(address: string): string {\n const normalized = normalizeSuiAddress(address);\n if (!isValidSuiAddress(normalized)) {\n throw new T2000Error('INVALID_ADDRESS', `Invalid Sui address: ${address}`);\n }\n return normalized;\n}\n\nexport function truncateAddress(address: string): string {\n if (address.length <= 10) return address;\n return `${address.slice(0, 6)}...${address.slice(-4)}`;\n}\n","import { Ed25519Keypair } from '@mysten/sui/keypairs/ed25519';\nimport { decodeSuiPrivateKey } from '@mysten/sui/cryptography';\nimport { randomBytes, createCipheriv, createDecipheriv, scryptSync } from 'node:crypto';\nimport { readFile, writeFile, mkdir, access } from 'node:fs/promises';\nimport { dirname, resolve } from 'node:path';\nimport { homedir } from 'node:os';\nimport { T2000Error } from '../errors.js';\nimport { DEFAULT_KEY_PATH } from '../constants.js';\n\nconst ALGORITHM = 'aes-256-gcm';\nconst SCRYPT_N = 2 ** 14; // 16384 — secure and fast enough\nconst SCRYPT_R = 8;\nconst SCRYPT_P = 1;\nconst SALT_LENGTH = 32;\nconst IV_LENGTH = 16;\nconst TAG_LENGTH = 16;\n\ninterface EncryptedKey {\n version: 1;\n algorithm: typeof ALGORITHM;\n salt: string;\n iv: string;\n tag: string;\n ciphertext: string;\n}\n\nfunction expandPath(p: string): string {\n if (p.startsWith('~')) return resolve(homedir(), p.slice(2));\n return resolve(p);\n}\n\nfunction deriveKey(passphrase: string, salt: Buffer): Buffer {\n return scryptSync(passphrase, salt, 32, { N: SCRYPT_N, r: SCRYPT_R, p: SCRYPT_P });\n}\n\nfunction encrypt(data: Buffer, passphrase: string): EncryptedKey {\n const salt = randomBytes(SALT_LENGTH);\n const key = deriveKey(passphrase, salt);\n const iv = randomBytes(IV_LENGTH);\n\n const cipher = createCipheriv(ALGORITHM, key, iv);\n const ciphertext = Buffer.concat([cipher.update(data), cipher.final()]);\n const tag = cipher.getAuthTag();\n\n return {\n version: 1,\n algorithm: ALGORITHM,\n salt: salt.toString('hex'),\n iv: iv.toString('hex'),\n tag: tag.toString('hex'),\n ciphertext: ciphertext.toString('hex'),\n };\n}\n\nfunction decrypt(encrypted: EncryptedKey, passphrase: string): Buffer {\n const salt = Buffer.from(encrypted.salt, 'hex');\n const key = deriveKey(passphrase, salt);\n const iv = Buffer.from(encrypted.iv, 'hex');\n const tag = Buffer.from(encrypted.tag, 'hex');\n const ciphertext = Buffer.from(encrypted.ciphertext, 'hex');\n\n const decipher = createDecipheriv(ALGORITHM, key, iv);\n decipher.setAuthTag(tag);\n\n try {\n return Buffer.concat([decipher.update(ciphertext), decipher.final()]);\n } catch {\n throw new T2000Error('WALLET_LOCKED', 'Invalid PIN');\n }\n}\n\nexport function generateKeypair(): Ed25519Keypair {\n return Ed25519Keypair.generate();\n}\n\nexport function keypairFromPrivateKey(privateKey: string): Ed25519Keypair {\n if (privateKey.startsWith('suiprivkey')) {\n const decoded = decodeSuiPrivateKey(privateKey);\n return Ed25519Keypair.fromSecretKey(decoded.secretKey);\n }\n const bytes = Buffer.from(privateKey.replace(/^0x/, ''), 'hex');\n return Ed25519Keypair.fromSecretKey(bytes);\n}\n\nexport async function saveKey(\n keypair: Ed25519Keypair,\n passphrase: string,\n keyPath?: string,\n): Promise<string> {\n const filePath = expandPath(keyPath ?? DEFAULT_KEY_PATH);\n\n try {\n await access(filePath);\n throw new T2000Error('WALLET_EXISTS', `Wallet already exists at ${filePath}`);\n } catch (error) {\n if (error instanceof T2000Error) throw error;\n }\n\n await mkdir(dirname(filePath), { recursive: true });\n\n const bech32Key = keypair.getSecretKey();\n const encrypted = encrypt(Buffer.from(bech32Key, 'utf-8'), passphrase);\n\n await writeFile(filePath, JSON.stringify(encrypted, null, 2), { mode: 0o600 });\n\n return filePath;\n}\n\nexport async function loadKey(passphrase: string, keyPath?: string): Promise<Ed25519Keypair> {\n const filePath = expandPath(keyPath ?? DEFAULT_KEY_PATH);\n\n let content: string;\n try {\n content = await readFile(filePath, 'utf-8');\n } catch {\n throw new T2000Error('WALLET_NOT_FOUND', `No wallet found at ${filePath}`);\n }\n\n const encrypted: EncryptedKey = JSON.parse(content);\n const decrypted = decrypt(encrypted, passphrase);\n const bech32Key = decrypted.toString('utf-8');\n const decoded = decodeSuiPrivateKey(bech32Key);\n\n return Ed25519Keypair.fromSecretKey(decoded.secretKey);\n}\n\nexport async function walletExists(keyPath?: string): Promise<boolean> {\n const filePath = expandPath(keyPath ?? DEFAULT_KEY_PATH);\n try {\n await access(filePath);\n return true;\n } catch {\n return false;\n }\n}\n\nexport function exportPrivateKey(keypair: Ed25519Keypair): string {\n return keypair.getSecretKey();\n}\n\nexport function getAddress(keypair: Ed25519Keypair): string {\n return keypair.getPublicKey().toSuiAddress();\n}\n","import { MIST_PER_SUI, BPS_DENOMINATOR, USDC_DECIMALS, SUI_DECIMALS } from '../constants.js';\n\nexport function mistToSui(mist: bigint): number {\n return Number(mist) / Number(MIST_PER_SUI);\n}\n\nexport function suiToMist(sui: number): bigint {\n return BigInt(Math.round(sui * Number(MIST_PER_SUI)));\n}\n\nexport function usdcToRaw(amount: number): bigint {\n return BigInt(Math.round(amount * 10 ** USDC_DECIMALS));\n}\n\nexport function rawToUsdc(raw: bigint): number {\n return Number(raw) / 10 ** USDC_DECIMALS;\n}\n\nexport function rawToDisplay(raw: bigint, decimals: number): number {\n return Number(raw) / 10 ** decimals;\n}\n\nexport function displayToRaw(amount: number, decimals: number): bigint {\n return BigInt(Math.round(amount * 10 ** decimals));\n}\n\nexport function bpsToPercent(bps: bigint): number {\n return Number(bps) / Number(BPS_DENOMINATOR) * 100;\n}\n\nexport function formatUsd(amount: number): string {\n return `$${amount.toFixed(2)}`;\n}\n\nexport function formatSui(amount: number): string {\n if (amount < 0.001) return `${amount.toFixed(6)} SUI`;\n return `${amount.toFixed(3)} SUI`;\n}\n\nexport function formatLargeNumber(n: number): string {\n if (n >= 1_000_000) return `${(n / 1_000_000).toFixed(1)}M`;\n if (n >= 1_000) return `${(n / 1_000).toFixed(1)}K`;\n return n.toFixed(2);\n}\n","import { Transaction } from '@mysten/sui/transactions';\nimport type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type { Ed25519Keypair } from '@mysten/sui/keypairs/ed25519';\nimport { SUPPORTED_ASSETS, type SupportedAsset } from '../constants.js';\nimport { T2000Error } from '../errors.js';\nimport { validateAddress } from '../utils/sui.js';\nimport { displayToRaw } from '../utils/format.js';\n\nexport interface SendParams {\n client: SuiJsonRpcClient;\n keypair: Ed25519Keypair;\n to: string;\n amount: number;\n asset?: SupportedAsset;\n}\n\nexport interface SendTxResult {\n digest: string;\n gasCost: number;\n}\n\nexport async function buildSendTx({\n client,\n address,\n to,\n amount,\n asset = 'USDC',\n}: { client: SuiJsonRpcClient; address: string; to: string; amount: number; asset?: SupportedAsset }): Promise<Transaction> {\n const recipient = validateAddress(to);\n const assetInfo = SUPPORTED_ASSETS[asset];\n\n if (!assetInfo) throw new T2000Error('ASSET_NOT_SUPPORTED', `Asset ${asset} is not supported`);\n if (amount <= 0) throw new T2000Error('INVALID_AMOUNT', 'Amount must be greater than zero');\n\n const rawAmount = displayToRaw(amount, assetInfo.decimals);\n const tx = new Transaction();\n tx.setSender(address);\n\n if (asset === 'SUI') {\n const [coin] = tx.splitCoins(tx.gas, [rawAmount]);\n tx.transferObjects([coin], recipient);\n } else {\n const coins = await client.getCoins({ owner: address, coinType: assetInfo.type });\n if (coins.data.length === 0) throw new T2000Error('INSUFFICIENT_BALANCE', `No ${asset} coins found`);\n\n const totalBalance = coins.data.reduce((sum, c) => sum + BigInt(c.balance), 0n);\n if (totalBalance < rawAmount) {\n throw new T2000Error('INSUFFICIENT_BALANCE', `Insufficient ${asset} balance`, {\n available: Number(totalBalance) / 10 ** assetInfo.decimals, required: amount,\n });\n }\n\n const primaryCoin = tx.object(coins.data[0].coinObjectId);\n if (coins.data.length > 1) {\n tx.mergeCoins(primaryCoin, coins.data.slice(1).map((c) => tx.object(c.coinObjectId)));\n }\n const [sendCoin] = tx.splitCoins(primaryCoin, [rawAmount]);\n tx.transferObjects([sendCoin], recipient);\n }\n\n return tx;\n}\n\nexport async function buildAndExecuteSend({\n client,\n keypair,\n to,\n amount,\n asset = 'USDC',\n}: SendParams): Promise<SendTxResult> {\n const recipient = validateAddress(to);\n const assetInfo = SUPPORTED_ASSETS[asset];\n\n if (!assetInfo) {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `Asset ${asset} is not supported`);\n }\n if (amount <= 0) {\n throw new T2000Error('INVALID_AMOUNT', 'Amount must be greater than zero');\n }\n\n const senderAddress = keypair.getPublicKey().toSuiAddress();\n const rawAmount = displayToRaw(amount, assetInfo.decimals);\n\n const tx = new Transaction();\n\n if (asset === 'SUI') {\n const [coin] = tx.splitCoins(tx.gas, [rawAmount]);\n tx.transferObjects([coin], recipient);\n } else {\n const coins = await client.getCoins({\n owner: senderAddress,\n coinType: assetInfo.type,\n });\n\n if (coins.data.length === 0) {\n throw new T2000Error('INSUFFICIENT_BALANCE', `No ${asset} coins found`);\n }\n\n const totalBalance = coins.data.reduce(\n (sum, c) => sum + BigInt(c.balance),\n 0n,\n );\n\n if (totalBalance < rawAmount) {\n throw new T2000Error('INSUFFICIENT_BALANCE', `Insufficient ${asset} balance`, {\n available: Number(totalBalance) / 10 ** assetInfo.decimals,\n required: amount,\n });\n }\n\n const primaryCoin = tx.object(coins.data[0].coinObjectId);\n\n if (coins.data.length > 1) {\n tx.mergeCoins(\n primaryCoin,\n coins.data.slice(1).map((c) => tx.object(c.coinObjectId)),\n );\n }\n\n const [sendCoin] = tx.splitCoins(primaryCoin, [rawAmount]);\n tx.transferObjects([sendCoin], recipient);\n }\n\n const result = await client.signAndExecuteTransaction({\n signer: keypair,\n transaction: tx,\n options: { showEffects: true },\n });\n\n await client.waitForTransaction({ digest: result.digest });\n\n const gasUsed = result.effects?.gasUsed;\n const gasCost = gasUsed\n ? Math.abs(\n (Number(gasUsed.computationCost) +\n Number(gasUsed.storageCost) -\n Number(gasUsed.storageRebate)) /\n 1e9\n )\n : 0;\n\n return {\n digest: result.digest,\n gasCost,\n };\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport { SUPPORTED_ASSETS, MIST_PER_SUI, CETUS_USDC_SUI_POOL } from '../constants.js';\nimport type { BalanceResponse } from '../types.js';\n\nlet _cachedSuiPrice = 0;\nlet _priceLastFetched = 0;\nconst PRICE_CACHE_TTL_MS = 60_000;\n\n/**\n * Fetch SUI price in USD from the Cetus USDC/SUI pool's sqrt_price.\n *\n * Pool is Pool<USDC, SUI> so coin_a = USDC (6 dec), coin_b = SUI (9 dec).\n * current_sqrt_price (Q64 fixed-point) encodes sqrt(raw_price) where\n * raw_price = SUI_raw / USDC_raw.\n *\n * USDC per SUI = 10^(decimals_a - decimals_b) / raw_price\n * = 10^(6-9) / raw_price\n * = 1 / (raw_price * 1000)\n *\n * Equivalently: 1000 / raw_price\n */\nasync function fetchSuiPrice(client: SuiJsonRpcClient): Promise<number> {\n const now = Date.now();\n if (_cachedSuiPrice > 0 && now - _priceLastFetched < PRICE_CACHE_TTL_MS) {\n return _cachedSuiPrice;\n }\n\n try {\n const pool = await client.getObject({\n id: CETUS_USDC_SUI_POOL,\n options: { showContent: true },\n });\n\n if (pool.data?.content?.dataType === 'moveObject') {\n const fields = pool.data.content.fields as Record<string, unknown>;\n const currentSqrtPrice = BigInt(String(fields.current_sqrt_price ?? '0'));\n\n if (currentSqrtPrice > 0n) {\n const Q64 = 2n ** 64n;\n const sqrtPriceFloat = Number(currentSqrtPrice) / Number(Q64);\n const rawPrice = sqrtPriceFloat * sqrtPriceFloat;\n const price = 1000 / rawPrice;\n if (price > 0.01 && price < 1000) {\n _cachedSuiPrice = price;\n _priceLastFetched = now;\n }\n }\n }\n } catch {\n // Use cached/fallback price\n }\n\n return _cachedSuiPrice;\n}\n\nexport async function queryBalance(\n client: SuiJsonRpcClient,\n address: string,\n): Promise<BalanceResponse> {\n const [usdcBalance, suiBalance, suiPriceUsd] = await Promise.all([\n client.getBalance({ owner: address, coinType: SUPPORTED_ASSETS.USDC.type }),\n client.getBalance({ owner: address, coinType: SUPPORTED_ASSETS.SUI.type }),\n fetchSuiPrice(client),\n ]);\n\n const usdcAmount = Number(usdcBalance.totalBalance) / 10 ** SUPPORTED_ASSETS.USDC.decimals;\n const suiAmount = Number(suiBalance.totalBalance) / Number(MIST_PER_SUI);\n\n const savings = 0; // Merged from NAVI in T2000.balance()\n const usdEquiv = suiAmount * suiPriceUsd;\n const total = usdcAmount + savings + usdEquiv;\n\n return {\n available: usdcAmount,\n savings,\n gasReserve: {\n sui: suiAmount,\n usdEquiv,\n },\n total,\n assets: {\n USDC: usdcAmount,\n SUI: suiAmount,\n },\n };\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type { TransactionRecord } from '../types.js';\n\nexport async function queryHistory(\n client: SuiJsonRpcClient,\n address: string,\n limit = 20,\n): Promise<TransactionRecord[]> {\n const txns = await client.queryTransactionBlocks({\n filter: { FromAddress: address },\n options: { showEffects: true, showInput: true },\n limit,\n order: 'descending',\n });\n\n return txns.data.map((tx) => {\n const gasUsed = tx.effects?.gasUsed;\n const gasCost = gasUsed\n ? (Number(gasUsed.computationCost) +\n Number(gasUsed.storageCost) -\n Number(gasUsed.storageRebate)) /\n 1e9\n : undefined;\n\n return {\n digest: tx.digest,\n action: inferAction(tx.transaction),\n timestamp: Number(tx.timestampMs ?? 0),\n gasCost,\n };\n });\n}\n\nfunction inferAction(txBlock: unknown): string {\n if (!txBlock || typeof txBlock !== 'object') return 'unknown';\n const data = 'data' in txBlock ? (txBlock as { data?: unknown }).data : undefined;\n if (!data || typeof data !== 'object') return 'unknown';\n const inner = 'transaction' in data ? (data as { transaction?: unknown }).transaction : undefined;\n if (!inner || typeof inner !== 'object') return 'unknown';\n\n const kind = 'kind' in inner ? (inner as { kind: string }).kind : undefined;\n if (kind === 'ProgrammableTransaction') return 'transaction';\n return kind ?? 'unknown';\n}\n","import { Transaction, type TransactionObjectArgument } from '@mysten/sui/transactions';\nimport type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport {\n SAVE_FEE_BPS,\n SWAP_FEE_BPS,\n BORROW_FEE_BPS,\n BPS_DENOMINATOR,\n SUPPORTED_ASSETS,\n T2000_PACKAGE_ID,\n T2000_TREASURY_ID,\n T2000_CONFIG_ID,\n API_BASE_URL,\n} from '../constants.js';\nimport { usdcToRaw } from '../utils/format.js';\n\nexport type FeeOperation = 'save' | 'swap' | 'borrow';\n\nexport interface ProtocolFeeInfo {\n amount: number;\n asset: string;\n rate: number;\n rawAmount: bigint;\n}\n\nconst FEE_RATES: Record<FeeOperation, bigint> = {\n save: SAVE_FEE_BPS,\n swap: SWAP_FEE_BPS,\n borrow: BORROW_FEE_BPS,\n};\n\nconst OP_CODES: Record<FeeOperation, number> = {\n save: 0,\n swap: 1,\n borrow: 2,\n};\n\nexport function calculateFee(operation: FeeOperation, amount: number): ProtocolFeeInfo {\n const bps = FEE_RATES[operation];\n const feeAmount = amount * Number(bps) / Number(BPS_DENOMINATOR);\n const rawAmount = usdcToRaw(feeAmount);\n\n return {\n amount: feeAmount,\n asset: 'USDC',\n rate: Number(bps) / Number(BPS_DENOMINATOR),\n rawAmount,\n };\n}\n\n/**\n * Add on-chain fee collection to an existing PTB via t2000::treasury::collect_fee().\n * The Move function splits the fee from the payment coin and stores it in the\n * Treasury's internal Balance<T>. Atomic — reverts with the operation if it fails.\n */\nexport function addCollectFeeToTx(\n tx: Transaction,\n paymentCoin: TransactionObjectArgument,\n operation: FeeOperation,\n): void {\n const bps = FEE_RATES[operation];\n if (bps <= 0n) return;\n\n tx.moveCall({\n target: `${T2000_PACKAGE_ID}::treasury::collect_fee`,\n typeArguments: [SUPPORTED_ASSETS.USDC.type],\n arguments: [\n tx.object(T2000_TREASURY_ID),\n tx.object(T2000_CONFIG_ID),\n paymentCoin,\n tx.pure.u8(OP_CODES[operation]),\n ],\n });\n}\n\nexport async function reportFee(\n agentAddress: string,\n operation: string,\n feeAmount: number,\n feeRate: number,\n txDigest: string,\n): Promise<void> {\n try {\n await fetch(`${API_BASE_URL}/api/fees`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({\n agentAddress,\n operation,\n feeAmount: feeAmount.toString(),\n feeRate: feeRate.toString(),\n txDigest,\n }),\n });\n } catch {\n // Non-critical — best-effort reporting\n }\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type { Ed25519Keypair } from '@mysten/sui/keypairs/ed25519';\nimport { Transaction, type TransactionObjectArgument } from '@mysten/sui/transactions';\nimport { bcs } from '@mysten/sui/bcs';\nimport { SUPPORTED_ASSETS } from '../constants.js';\nimport { T2000Error } from '../errors.js';\nimport { usdcToRaw } from '../utils/format.js';\nimport { addCollectFeeToTx } from './protocolFee.js';\nimport type {\n SaveResult,\n WithdrawResult,\n BorrowResult,\n RepayResult,\n GasMethod,\n RatesResult,\n PositionsResult,\n PositionEntry,\n HealthFactorResult,\n MaxWithdrawResult,\n MaxBorrowResult,\n} from '../types.js';\n\nconst USDC_TYPE = SUPPORTED_ASSETS.USDC.type;\nconst RATE_DECIMALS = 27;\nconst LTV_DECIMALS = 27;\nconst MIN_HEALTH_FACTOR = 1.5;\nconst WITHDRAW_DUST_BUFFER = 0.001;\nconst CLOCK = '0x06';\nconst SUI_SYSTEM_STATE = '0x05';\nconst NAVI_BALANCE_DECIMALS = 9;\nconst CONFIG_API = 'https://open-api.naviprotocol.io/api/navi/config?env=prod';\nconst POOLS_API = 'https://open-api.naviprotocol.io/api/navi/pools?env=prod';\n\nconst PACKAGE_API = 'https://open-api.naviprotocol.io/api/package';\nlet packageCache: { id: string; ts: number } | null = null;\n\n// ---------------------------------------------------------------------------\n// Types\n// ---------------------------------------------------------------------------\n\ninterface OracleFeed {\n oracleId: number;\n assetId: number;\n feedId: string;\n pythPriceInfoObject: string;\n}\n\ninterface NaviConfig {\n package: string;\n storage: string;\n incentiveV2: string;\n incentiveV3: string;\n uiGetter: string;\n oracle: {\n packageId: string;\n priceOracle: string;\n oracleConfig: string;\n supraOracleHolder: string;\n switchboardAggregator: string;\n feeds: OracleFeed[];\n };\n}\n\n// Oracle package ID comes from config.oracle.packageId (not hardcoded)\n\ninterface NaviPool {\n id: number;\n coinType: string;\n suiCoinType: string;\n currentSupplyRate: string;\n currentBorrowRate: string;\n currentSupplyIndex: string;\n currentBorrowIndex: string;\n ltv: string;\n liquidationFactor: { bonus: string; ratio: string; threshold: string };\n contract: { reserveId: string; pool: string };\n token: { symbol: string; decimals: number; price: number };\n}\n\ninterface UserState {\n assetId: number;\n supplyBalance: bigint;\n borrowBalance: bigint;\n}\n\nfunction toBigInt(v: unknown): bigint {\n if (typeof v === 'bigint') return v;\n return BigInt(String(v));\n}\n\n// ---------------------------------------------------------------------------\n// BCS\n// ---------------------------------------------------------------------------\n\nconst UserStateInfo = bcs.struct('UserStateInfo', {\n asset_id: bcs.u8(),\n borrow_balance: bcs.u256(),\n supply_balance: bcs.u256(),\n});\n\nfunction decodeDevInspect<T>(\n result: { results?: Array<{ returnValues?: Array<[number[], string]> }> | null; error?: string | null },\n schema: { parse: (data: Uint8Array) => T },\n): T | undefined {\n const rv = result.results?.[0]?.returnValues?.[0];\n if (result.error || !rv) return undefined;\n const bytes = Uint8Array.from(rv[0]);\n return schema.parse(bytes);\n}\n\n// ---------------------------------------------------------------------------\n// Config + Pool cache\n// ---------------------------------------------------------------------------\n\nlet configCache: { data: NaviConfig; ts: number } | null = null;\nlet poolsCache: { data: NaviPool[]; ts: number } | null = null;\nconst CACHE_TTL = 5 * 60_000;\n\nasync function fetchJson<T>(url: string): Promise<T> {\n const res = await fetch(url);\n if (!res.ok) throw new T2000Error('PROTOCOL_UNAVAILABLE', `NAVI API error: ${res.status}`);\n const json = (await res.json()) as { data?: T; code?: number };\n return (json.data ?? json) as T;\n}\n\nasync function getLatestPackageId(): Promise<string> {\n if (packageCache && Date.now() - packageCache.ts < CACHE_TTL) return packageCache.id;\n const res = await fetch(PACKAGE_API);\n if (!res.ok) throw new T2000Error('PROTOCOL_UNAVAILABLE', `NAVI package API error: ${res.status}`);\n const json = (await res.json()) as { packageId?: string };\n if (!json.packageId) throw new T2000Error('PROTOCOL_UNAVAILABLE', 'NAVI package API returned no packageId');\n packageCache = { id: json.packageId, ts: Date.now() };\n return json.packageId;\n}\n\nasync function getConfig(fresh = false): Promise<NaviConfig> {\n if (configCache && !fresh && Date.now() - configCache.ts < CACHE_TTL) return configCache.data;\n const [data, latestPkg] = await Promise.all([\n fetchJson<NaviConfig>(CONFIG_API),\n getLatestPackageId(),\n ]);\n data.package = latestPkg;\n configCache = { data, ts: Date.now() };\n return data;\n}\n\nasync function getPools(fresh = false): Promise<NaviPool[]> {\n if (poolsCache && !fresh && Date.now() - poolsCache.ts < CACHE_TTL) return poolsCache.data;\n const data = await fetchJson<NaviPool[]>(POOLS_API);\n poolsCache = { data, ts: Date.now() };\n return data;\n}\n\nasync function getUsdcPool(): Promise<NaviPool> {\n const pools = await getPools();\n const usdc = pools.find(\n (p) => p.token?.symbol === 'USDC' || p.coinType?.toLowerCase().includes('usdc'),\n );\n if (!usdc) throw new T2000Error('PROTOCOL_UNAVAILABLE', 'USDC pool not found on NAVI');\n return usdc;\n}\n\n// ---------------------------------------------------------------------------\n// Oracle price update (required before withdraw/borrow)\n// ---------------------------------------------------------------------------\n\nfunction addOracleUpdate(tx: Transaction, config: NaviConfig, pool: NaviPool): void {\n const feed = config.oracle.feeds?.find((f) => f.assetId === pool.id);\n if (!feed) {\n throw new T2000Error('PROTOCOL_UNAVAILABLE', `Oracle feed not found for asset ${pool.token?.symbol ?? pool.id}`);\n }\n\n tx.moveCall({\n target: `${config.oracle.packageId}::oracle_pro::update_single_price_v2`,\n arguments: [\n tx.object(CLOCK),\n tx.object(config.oracle.oracleConfig),\n tx.object(config.oracle.priceOracle),\n tx.object(config.oracle.supraOracleHolder),\n tx.object(feed.pythPriceInfoObject),\n tx.object(config.oracle.switchboardAggregator),\n tx.pure.address(feed.feedId),\n ],\n });\n}\n\n// ---------------------------------------------------------------------------\n// Helpers\n// ---------------------------------------------------------------------------\n\nfunction extractGasCost(effects: { gasUsed?: { computationCost: string; storageCost: string; storageRebate: string } } | undefined | null): number {\n if (!effects?.gasUsed) return 0;\n return Math.abs(\n (Number(effects.gasUsed.computationCost) +\n Number(effects.gasUsed.storageCost) -\n Number(effects.gasUsed.storageRebate)) / 1e9,\n );\n}\n\nfunction rateToApy(rawRate: string): number {\n if (!rawRate || rawRate === '0') return 0;\n return Number(BigInt(rawRate)) / 10 ** RATE_DECIMALS * 100;\n}\n\nfunction parseLtv(rawLtv: string): number {\n if (!rawLtv || rawLtv === '0') return 0.75;\n return Number(BigInt(rawLtv)) / 10 ** LTV_DECIMALS;\n}\n\nfunction parseLiqThreshold(val: string | number): number {\n if (typeof val === 'number') return val;\n const n = Number(val);\n if (n > 1) return Number(BigInt(val)) / 10 ** LTV_DECIMALS;\n return n;\n}\n\nfunction normalizeHealthFactor(raw: number): number {\n const v = raw / 10 ** RATE_DECIMALS;\n return v > 1e5 ? Infinity : v;\n}\n\nfunction compoundBalance(rawBalance: bigint, currentIndex: string): number {\n if (!rawBalance || !currentIndex || currentIndex === '0') return 0;\n const scale = BigInt('1' + '0'.repeat(RATE_DECIMALS));\n const half = scale / 2n;\n const result = (rawBalance * BigInt(currentIndex) + half) / scale;\n return Number(result) / 10 ** NAVI_BALANCE_DECIMALS;\n}\n\n// ---------------------------------------------------------------------------\n// On-chain reads\n// ---------------------------------------------------------------------------\n\nasync function getUserState(client: SuiJsonRpcClient, address: string): Promise<UserState[]> {\n const config = await getConfig();\n const tx = new Transaction();\n tx.moveCall({\n target: `${config.uiGetter}::getter_unchecked::get_user_state`,\n arguments: [tx.object(config.storage), tx.pure.address(address)],\n });\n\n const result = await client.devInspectTransactionBlock({\n transactionBlock: tx,\n sender: address,\n });\n\n const decoded = decodeDevInspect(result, bcs.vector(UserStateInfo));\n if (!decoded) return [];\n\n return (decoded as Array<{ asset_id: number; supply_balance: unknown; borrow_balance: unknown }>)\n .map((s) => ({\n assetId: s.asset_id,\n supplyBalance: toBigInt(s.supply_balance),\n borrowBalance: toBigInt(s.borrow_balance),\n }))\n .filter((s) => s.supplyBalance !== 0n || s.borrowBalance !== 0n);\n}\n\nasync function fetchCoins(\n client: SuiJsonRpcClient,\n owner: string,\n coinType: string,\n): Promise<Array<{ coinObjectId: string; balance: string }>> {\n const all: Array<{ coinObjectId: string; balance: string }> = [];\n let cursor: string | null | undefined;\n let hasNext = true;\n\n while (hasNext) {\n const page = await client.getCoins({ owner, coinType, cursor: cursor ?? undefined });\n all.push(...page.data.map((c) => ({ coinObjectId: c.coinObjectId, balance: c.balance })));\n cursor = page.nextCursor;\n hasNext = page.hasNextPage;\n }\n\n return all;\n}\n\nfunction mergeCoins(\n tx: Transaction,\n coins: Array<{ coinObjectId: string; balance: string }>,\n): TransactionObjectArgument {\n if (coins.length === 0) throw new T2000Error('INSUFFICIENT_BALANCE', 'No coins to merge');\n\n const primary = tx.object(coins[0].coinObjectId);\n if (coins.length > 1) {\n tx.mergeCoins(primary, coins.slice(1).map((c) => tx.object(c.coinObjectId)));\n }\n\n return primary;\n}\n\n// ---------------------------------------------------------------------------\n// Public API\n// ---------------------------------------------------------------------------\n\nexport async function buildSaveTx(\n client: SuiJsonRpcClient,\n address: string,\n amount: number,\n options: { collectFee?: boolean } = {},\n): Promise<Transaction> {\n if (!amount || amount <= 0 || !Number.isFinite(amount)) {\n throw new T2000Error('INVALID_AMOUNT', 'Save amount must be a positive number');\n }\n const rawAmount = Number(usdcToRaw(amount));\n const [config, pool] = await Promise.all([getConfig(), getUsdcPool()]);\n\n const coins = await fetchCoins(client, address, USDC_TYPE);\n if (coins.length === 0) throw new T2000Error('INSUFFICIENT_BALANCE', 'No USDC coins found');\n\n const tx = new Transaction();\n tx.setSender(address);\n\n const coinObj = mergeCoins(tx, coins);\n\n if (options.collectFee) {\n addCollectFeeToTx(tx, coinObj, 'save');\n }\n\n tx.moveCall({\n target: `${config.package}::incentive_v3::entry_deposit`,\n arguments: [\n tx.object(CLOCK),\n tx.object(config.storage),\n tx.object(pool.contract.pool),\n tx.pure.u8(pool.id),\n coinObj,\n tx.pure.u64(rawAmount),\n tx.object(config.incentiveV2),\n tx.object(config.incentiveV3),\n ],\n typeArguments: [pool.suiCoinType],\n });\n\n return tx;\n}\n\nexport async function save(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n amount: number,\n): Promise<SaveResult> {\n const address = keypair.getPublicKey().toSuiAddress();\n const tx = await buildSaveTx(client, address, amount);\n\n const result = await client.signAndExecuteTransaction({\n signer: keypair,\n transaction: tx,\n options: { showEffects: true },\n });\n await client.waitForTransaction({ digest: result.digest });\n\n const rates = await getRates(client);\n\n return {\n success: true,\n tx: result.digest,\n amount,\n apy: rates.USDC.saveApy,\n fee: 0,\n gasCost: extractGasCost(result.effects),\n gasMethod: 'self-funded' as GasMethod,\n savingsBalance: amount,\n };\n}\n\nexport async function buildWithdrawTx(\n client: SuiJsonRpcClient,\n address: string,\n amount: number,\n): Promise<{ tx: Transaction; effectiveAmount: number }> {\n const [config, pool, pools, states] = await Promise.all([\n getConfig(),\n getUsdcPool(),\n getPools(),\n getUserState(client, address),\n ]);\n\n const usdcState = states.find((s) => s.assetId === pool.id);\n const deposited = usdcState ? compoundBalance(usdcState.supplyBalance, pool.currentSupplyIndex) : 0;\n\n const effectiveAmount = Math.min(amount, Math.max(0, deposited - WITHDRAW_DUST_BUFFER));\n if (effectiveAmount <= 0) throw new T2000Error('NO_COLLATERAL', 'Nothing to withdraw');\n\n const rawAmount = Number(usdcToRaw(effectiveAmount));\n const tx = new Transaction();\n tx.setSender(address);\n\n addOracleUpdate(tx, config, pool);\n\n const [balance] = tx.moveCall({\n target: `${config.package}::incentive_v3::withdraw_v2`,\n arguments: [\n tx.object(CLOCK),\n tx.object(config.oracle.priceOracle),\n tx.object(config.storage),\n tx.object(pool.contract.pool),\n tx.pure.u8(pool.id),\n tx.pure.u64(rawAmount),\n tx.object(config.incentiveV2),\n tx.object(config.incentiveV3),\n tx.object(SUI_SYSTEM_STATE),\n ],\n typeArguments: [pool.suiCoinType],\n });\n\n const [coin] = tx.moveCall({\n target: '0x2::coin::from_balance',\n arguments: [balance],\n typeArguments: [pool.suiCoinType],\n });\n\n tx.transferObjects([coin], address);\n\n return { tx, effectiveAmount };\n}\n\nexport async function withdraw(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n amount: number,\n): Promise<WithdrawResult> {\n const address = keypair.getPublicKey().toSuiAddress();\n const { tx, effectiveAmount } = await buildWithdrawTx(client, address, amount);\n\n const result = await client.signAndExecuteTransaction({\n signer: keypair,\n transaction: tx,\n options: { showEffects: true },\n });\n await client.waitForTransaction({ digest: result.digest });\n\n return {\n success: true,\n tx: result.digest,\n amount: effectiveAmount,\n gasCost: extractGasCost(result.effects),\n gasMethod: 'self-funded' as GasMethod,\n };\n}\n\nexport async function buildBorrowTx(\n client: SuiJsonRpcClient,\n address: string,\n amount: number,\n options: { collectFee?: boolean } = {},\n): Promise<Transaction> {\n if (!amount || amount <= 0 || !Number.isFinite(amount)) {\n throw new T2000Error('INVALID_AMOUNT', 'Borrow amount must be a positive number');\n }\n const rawAmount = Number(usdcToRaw(amount));\n const [config, pool] = await Promise.all([getConfig(), getUsdcPool()]);\n\n const tx = new Transaction();\n tx.setSender(address);\n\n addOracleUpdate(tx, config, pool);\n\n const [balance] = tx.moveCall({\n target: `${config.package}::incentive_v3::borrow_v2`,\n arguments: [\n tx.object(CLOCK),\n tx.object(config.oracle.priceOracle),\n tx.object(config.storage),\n tx.object(pool.contract.pool),\n tx.pure.u8(pool.id),\n tx.pure.u64(rawAmount),\n tx.object(config.incentiveV2),\n tx.object(config.incentiveV3),\n tx.object(SUI_SYSTEM_STATE),\n ],\n typeArguments: [pool.suiCoinType],\n });\n\n const [borrowedCoin] = tx.moveCall({\n target: '0x2::coin::from_balance',\n arguments: [balance],\n typeArguments: [pool.suiCoinType],\n });\n\n if (options.collectFee) {\n addCollectFeeToTx(tx, borrowedCoin, 'borrow');\n }\n\n tx.transferObjects([borrowedCoin], address);\n\n return tx;\n}\n\nexport async function borrow(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n amount: number,\n): Promise<BorrowResult> {\n const address = keypair.getPublicKey().toSuiAddress();\n const tx = await buildBorrowTx(client, address, amount);\n\n const result = await client.signAndExecuteTransaction({\n signer: keypair,\n transaction: tx,\n options: { showEffects: true },\n });\n await client.waitForTransaction({ digest: result.digest });\n\n const hfResult = await getHealthFactor(client, address);\n\n return {\n success: true,\n tx: result.digest,\n amount,\n fee: 0,\n healthFactor: hfResult.healthFactor,\n gasCost: extractGasCost(result.effects),\n gasMethod: 'self-funded' as GasMethod,\n };\n}\n\nexport async function buildRepayTx(\n client: SuiJsonRpcClient,\n address: string,\n amount: number,\n): Promise<Transaction> {\n if (!amount || amount <= 0 || !Number.isFinite(amount)) {\n throw new T2000Error('INVALID_AMOUNT', 'Repay amount must be a positive number');\n }\n const rawAmount = Number(usdcToRaw(amount));\n const [config, pool] = await Promise.all([getConfig(), getUsdcPool()]);\n\n const coins = await fetchCoins(client, address, USDC_TYPE);\n if (coins.length === 0) throw new T2000Error('INSUFFICIENT_BALANCE', 'No USDC coins to repay with');\n\n const tx = new Transaction();\n tx.setSender(address);\n\n addOracleUpdate(tx, config, pool);\n\n const coinObj = mergeCoins(tx, coins);\n\n tx.moveCall({\n target: `${config.package}::incentive_v3::entry_repay`,\n arguments: [\n tx.object(CLOCK),\n tx.object(config.oracle.priceOracle),\n tx.object(config.storage),\n tx.object(pool.contract.pool),\n tx.pure.u8(pool.id),\n coinObj,\n tx.pure.u64(rawAmount),\n tx.object(config.incentiveV2),\n tx.object(config.incentiveV3),\n ],\n typeArguments: [pool.suiCoinType],\n });\n\n return tx;\n}\n\nexport async function repay(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n amount: number,\n): Promise<RepayResult> {\n const address = keypair.getPublicKey().toSuiAddress();\n const tx = await buildRepayTx(client, address, amount);\n\n const result = await client.signAndExecuteTransaction({\n signer: keypair,\n transaction: tx,\n options: { showEffects: true },\n });\n await client.waitForTransaction({ digest: result.digest });\n\n const states = await getUserState(client, address);\n const pool = await getUsdcPool();\n const usdcState = states.find((s) => s.assetId === pool.id);\n const remainingDebt = usdcState ? compoundBalance(usdcState.borrowBalance, pool.currentBorrowIndex) : 0;\n\n return {\n success: true,\n tx: result.digest,\n amount,\n remainingDebt,\n gasCost: extractGasCost(result.effects),\n gasMethod: 'self-funded' as GasMethod,\n };\n}\n\nexport async function getHealthFactor(\n client: SuiJsonRpcClient,\n addressOrKeypair: string | Ed25519Keypair,\n): Promise<HealthFactorResult> {\n const address = typeof addressOrKeypair === 'string'\n ? addressOrKeypair\n : addressOrKeypair.getPublicKey().toSuiAddress();\n\n const [config, pool, states] = await Promise.all([\n getConfig(),\n getUsdcPool(),\n getUserState(client, address),\n ]);\n\n const usdcState = states.find((s) => s.assetId === pool.id);\n const supplied = usdcState ? compoundBalance(usdcState.supplyBalance, pool.currentSupplyIndex) : 0;\n const borrowed = usdcState ? compoundBalance(usdcState.borrowBalance, pool.currentBorrowIndex) : 0;\n\n const ltv = parseLtv(pool.ltv);\n const liqThreshold = parseLiqThreshold(pool.liquidationFactor.threshold);\n const maxBorrowVal = Math.max(0, supplied * ltv - borrowed);\n\n let healthFactor: number;\n if (borrowed <= 0) {\n healthFactor = Infinity;\n } else {\n try {\n const tx = new Transaction();\n tx.moveCall({\n target: `${config.uiGetter}::calculator_unchecked::dynamic_health_factor`,\n arguments: [\n tx.object(CLOCK),\n tx.object(config.storage),\n tx.object(config.oracle.priceOracle),\n tx.pure.u8(pool.id),\n tx.pure.address(address),\n tx.pure.u8(pool.id),\n tx.pure.u64(0),\n tx.pure.u64(0),\n tx.pure.bool(false),\n ],\n typeArguments: [pool.suiCoinType],\n });\n\n const result = await client.devInspectTransactionBlock({\n transactionBlock: tx,\n sender: address,\n });\n\n const decoded = decodeDevInspect(result, bcs.u256());\n if (decoded !== undefined) {\n healthFactor = normalizeHealthFactor(Number(decoded));\n } else {\n healthFactor = borrowed > 0 ? (supplied * liqThreshold) / borrowed : Infinity;\n }\n } catch {\n healthFactor = borrowed > 0 ? (supplied * liqThreshold) / borrowed : Infinity;\n }\n }\n\n return {\n healthFactor,\n supplied,\n borrowed,\n maxBorrow: maxBorrowVal,\n liquidationThreshold: liqThreshold,\n };\n}\n\nexport async function getRates(client: SuiJsonRpcClient): Promise<RatesResult> {\n try {\n const pool = await getUsdcPool();\n\n let saveApy = rateToApy(pool.currentSupplyRate);\n let borrowApy = rateToApy(pool.currentBorrowRate);\n\n if (saveApy <= 0 || saveApy > 100) saveApy = 4.0;\n if (borrowApy <= 0 || borrowApy > 100) borrowApy = 6.0;\n\n return { USDC: { saveApy, borrowApy } };\n } catch {\n return { USDC: { saveApy: 4.0, borrowApy: 6.0 } };\n }\n}\n\nexport async function getPositions(\n client: SuiJsonRpcClient,\n addressOrKeypair: string | Ed25519Keypair,\n): Promise<PositionsResult> {\n const address = typeof addressOrKeypair === 'string'\n ? addressOrKeypair\n : addressOrKeypair.getPublicKey().toSuiAddress();\n\n const [states, pools] = await Promise.all([getUserState(client, address), getPools()]);\n const positions: PositionEntry[] = [];\n\n for (const state of states) {\n const pool = pools.find((p) => p.id === state.assetId);\n if (!pool) continue;\n\n const symbol = pool.token?.symbol ?? 'UNKNOWN';\n const supplyBal = compoundBalance(state.supplyBalance, pool.currentSupplyIndex);\n const borrowBal = compoundBalance(state.borrowBalance, pool.currentBorrowIndex);\n\n if (supplyBal > 0.0001) {\n positions.push({\n protocol: 'navi',\n asset: symbol,\n type: 'save',\n amount: supplyBal,\n apy: rateToApy(pool.currentSupplyRate),\n });\n }\n\n if (borrowBal > 0.0001) {\n positions.push({\n protocol: 'navi',\n asset: symbol,\n type: 'borrow',\n amount: borrowBal,\n apy: rateToApy(pool.currentBorrowRate),\n });\n }\n }\n\n return { positions };\n}\n\nexport async function maxWithdrawAmount(\n client: SuiJsonRpcClient,\n addressOrKeypair: string | Ed25519Keypair,\n): Promise<MaxWithdrawResult> {\n const hf = await getHealthFactor(client, addressOrKeypair);\n const ltv = hf.liquidationThreshold > 0 ? hf.liquidationThreshold : 0.75;\n\n let maxAmount: number;\n if (hf.borrowed === 0) {\n maxAmount = hf.supplied;\n } else {\n maxAmount = Math.max(0, hf.supplied - (hf.borrowed * MIN_HEALTH_FACTOR / ltv));\n }\n\n const remainingSupply = hf.supplied - maxAmount;\n const hfAfter = hf.borrowed > 0 ? remainingSupply / hf.borrowed : Infinity;\n\n return { maxAmount, healthFactorAfter: hfAfter, currentHF: hf.healthFactor };\n}\n\nexport async function maxBorrowAmount(\n client: SuiJsonRpcClient,\n addressOrKeypair: string | Ed25519Keypair,\n): Promise<MaxBorrowResult> {\n const hf = await getHealthFactor(client, addressOrKeypair);\n const ltv = hf.liquidationThreshold > 0 ? hf.liquidationThreshold : 0.75;\n\n const maxAmount = Math.max(0, hf.supplied * ltv / MIN_HEALTH_FACTOR - hf.borrowed);\n\n return { maxAmount, healthFactorAfter: MIN_HEALTH_FACTOR, currentHF: hf.healthFactor };\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type { Ed25519Keypair } from '@mysten/sui/keypairs/ed25519';\nimport * as navi from './navi.js';\nimport type { EarningsResult, FundStatusResult } from '../types.js';\n\nexport async function getEarnings(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n): Promise<EarningsResult> {\n const hf = await navi.getHealthFactor(client, keypair);\n const rates = await navi.getRates(client);\n\n const supplied = hf.supplied;\n const apy = rates.USDC.saveApy / 100;\n const dailyRate = apy / 365;\n const dailyEarning = supplied * dailyRate;\n\n // Estimate total yield earned based on position age\n // For MVP, use a simple approximation\n const totalYieldEarned = dailyEarning * 30; // rough monthly estimate\n\n return {\n totalYieldEarned,\n currentApy: rates.USDC.saveApy,\n dailyEarning,\n supplied,\n };\n}\n\nexport async function getFundStatus(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n): Promise<FundStatusResult> {\n const earnings = await getEarnings(client, keypair);\n\n return {\n supplied: earnings.supplied,\n apy: earnings.currentApy,\n earnedToday: earnings.dailyEarning,\n earnedAllTime: earnings.totalYieldEarned,\n projectedMonthly: earnings.dailyEarning * 30,\n };\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type { Ed25519Keypair } from '@mysten/sui/keypairs/ed25519';\nimport { Transaction } from '@mysten/sui/transactions';\nimport { bcs } from '@mysten/sui/bcs';\nimport { SENTINEL, CLOCK_ID, MIST_PER_SUI } from '../constants.js';\nimport { T2000Error } from '../errors.js';\nimport type { SentinelAgent, SentinelVerdict, SentinelAttackResult } from '../types.js';\nimport type { ProtocolDescriptor } from '../adapters/types.js';\n\nexport const descriptor: ProtocolDescriptor = {\n id: 'sentinel',\n name: 'Sui Sentinel',\n packages: [SENTINEL.PACKAGE],\n actionMap: {\n 'sentinel::request_attack': 'sentinel_attack',\n 'sentinel::consume_prompt': 'sentinel_settle',\n },\n};\n\ninterface RawSentinelAgent {\n agent_id: string;\n agent_object_id: string;\n agent_name: string;\n cost_per_message: string;\n total_balance: string;\n total_attacks: number;\n successful_breaches?: number;\n state: string;\n prompt: string;\n model?: string;\n}\n\nfunction mapAgent(raw: RawSentinelAgent): SentinelAgent {\n return {\n id: raw.agent_id,\n objectId: raw.agent_object_id,\n name: raw.agent_name,\n model: raw.model ?? 'unknown',\n systemPrompt: raw.prompt,\n attackFee: BigInt(raw.cost_per_message),\n prizePool: BigInt(raw.total_balance),\n totalAttacks: raw.total_attacks,\n successfulBreaches: raw.successful_breaches ?? 0,\n state: raw.state,\n };\n}\n\nexport async function listSentinels(): Promise<SentinelAgent[]> {\n const res = await fetch(SENTINEL.SENTINELS_API);\n if (!res.ok) {\n throw new T2000Error('SENTINEL_API_ERROR', `Sentinel API returned ${res.status}`);\n }\n\n const data = (await res.json()) as { agents: RawSentinelAgent[] };\n if (!Array.isArray(data.agents)) {\n throw new T2000Error('SENTINEL_API_ERROR', 'Unexpected API response shape');\n }\n\n return data.agents\n .filter((a) => a.state === 'active')\n .map(mapAgent);\n}\n\nexport async function getSentinelInfo(\n client: SuiJsonRpcClient,\n sentinelObjectId: string,\n): Promise<SentinelAgent> {\n const agents = await listSentinels();\n const match = agents.find((a) => a.objectId === sentinelObjectId || a.id === sentinelObjectId);\n\n if (match) return match;\n\n const obj = await client.getObject({\n id: sentinelObjectId,\n options: { showContent: true, showType: true },\n });\n\n if (!obj.data) {\n throw new T2000Error('SENTINEL_NOT_FOUND', `Sentinel ${sentinelObjectId} not found on-chain`);\n }\n\n const content = obj.data.content;\n if (!content || content.dataType !== 'moveObject') {\n throw new T2000Error('SENTINEL_NOT_FOUND', `Object ${sentinelObjectId} is not a Move object`);\n }\n\n const fields = content.fields as Record<string, unknown>;\n\n return {\n id: (fields.id as { id: string })?.id ?? sentinelObjectId,\n objectId: sentinelObjectId,\n name: (fields.name as string) ?? 'Unknown',\n model: (fields.model as string) ?? 'unknown',\n systemPrompt: (fields.system_prompt as string) ?? '',\n attackFee: BigInt((fields.cost_per_message as string) ?? '0'),\n prizePool: BigInt((fields.balance as string) ?? '0'),\n totalAttacks: Number((fields.total_attacks as string) ?? '0'),\n successfulBreaches: Number((fields.successful_breaches as string) ?? '0'),\n state: (fields.state as string) ?? 'unknown',\n };\n}\n\nexport async function requestAttack(\n client: SuiJsonRpcClient,\n signer: Ed25519Keypair,\n sentinelObjectId: string,\n feeMist: bigint,\n): Promise<{ attackObjectId: string; digest: string }> {\n if (feeMist < SENTINEL.MIN_FEE_MIST) {\n throw new T2000Error('INVALID_AMOUNT', `Attack fee must be at least 0.1 SUI (${SENTINEL.MIN_FEE_MIST} MIST)`);\n }\n\n const tx = new Transaction();\n const [coin] = tx.splitCoins(tx.gas, [Number(feeMist)]);\n\n const [attack] = tx.moveCall({\n target: `${SENTINEL.PACKAGE}::sentinel::request_attack`,\n arguments: [\n tx.object(SENTINEL.AGENT_REGISTRY),\n tx.object(sentinelObjectId),\n tx.object(SENTINEL.PROTOCOL_CONFIG),\n coin,\n tx.object(SENTINEL.RANDOM),\n tx.object(CLOCK_ID),\n ],\n });\n\n const address = signer.toSuiAddress();\n tx.transferObjects([attack], address);\n\n const result = await client.signAndExecuteTransaction({\n signer,\n transaction: tx,\n options: { showObjectChanges: true, showEffects: true },\n });\n\n await client.waitForTransaction({ digest: result.digest });\n\n const attackObj = result.objectChanges?.find(\n (c) => c.type === 'created' && c.objectType?.includes('::sentinel::Attack'),\n );\n\n const attackObjectId = attackObj && 'objectId' in attackObj ? attackObj.objectId : undefined;\n\n if (!attackObjectId) {\n throw new T2000Error('SENTINEL_TX_FAILED', 'Attack object was not created — transaction may have failed');\n }\n\n return { attackObjectId, digest: result.digest };\n}\n\nexport async function submitPrompt(\n agentId: string,\n attackObjectId: string,\n prompt: string,\n): Promise<SentinelVerdict> {\n const res = await fetch(SENTINEL.TEE_API, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({\n agent_id: agentId,\n attack_object_id: attackObjectId,\n message: prompt,\n }),\n });\n\n if (!res.ok) {\n const body = await res.text().catch(() => '');\n throw new T2000Error('SENTINEL_TEE_ERROR', `TEE returned ${res.status}: ${body.slice(0, 200)}`);\n }\n\n const raw = await res.json() as Record<string, unknown>;\n\n // TEE wraps: { response: { intent, timestamp_ms, data: { ... } }, signature }\n const envelope = (raw.response ?? raw) as Record<string, unknown>;\n const data = (envelope.data ?? envelope) as Record<string, unknown>;\n const signature = (raw.signature ?? data.signature) as string;\n const timestampMs = (envelope.timestamp_ms ?? data.timestamp_ms) as number;\n\n if (typeof signature !== 'string') {\n throw new T2000Error('SENTINEL_TEE_ERROR', 'TEE response missing signature');\n }\n\n return {\n success: (data.success ?? data.is_success) as boolean,\n score: data.score as number,\n agentResponse: data.agent_response as string,\n juryResponse: data.jury_response as string,\n funResponse: (data.fun_response as string) ?? '',\n signature,\n timestampMs,\n };\n}\n\nexport async function settleAttack(\n client: SuiJsonRpcClient,\n signer: Ed25519Keypair,\n sentinelObjectId: string,\n attackObjectId: string,\n prompt: string,\n verdict: SentinelVerdict,\n): Promise<{ digest: string; success: boolean }> {\n const sigBytes = Array.from(Buffer.from(verdict.signature.replace(/^0x/, ''), 'hex'));\n\n const tx = new Transaction();\n tx.moveCall({\n target: `${SENTINEL.PACKAGE}::sentinel::consume_prompt`,\n arguments: [\n tx.object(SENTINEL.AGENT_REGISTRY),\n tx.object(SENTINEL.PROTOCOL_CONFIG),\n tx.object(sentinelObjectId),\n tx.pure.bool(verdict.success),\n tx.pure.string(verdict.agentResponse),\n tx.pure.string(verdict.juryResponse),\n tx.pure.string(verdict.funResponse),\n tx.pure.string(prompt),\n tx.pure.u8(verdict.score),\n tx.pure.u64(verdict.timestampMs),\n tx.pure(bcs.vector(bcs.u8()).serialize(sigBytes)),\n tx.object(SENTINEL.ENCLAVE),\n tx.object(attackObjectId),\n tx.object(CLOCK_ID),\n ],\n });\n\n const result = await client.signAndExecuteTransaction({\n signer,\n transaction: tx,\n options: { showEffects: true },\n });\n\n await client.waitForTransaction({ digest: result.digest });\n\n const txSuccess = result.effects?.status?.status === 'success';\n\n return { digest: result.digest, success: txSuccess };\n}\n\nexport async function attack(\n client: SuiJsonRpcClient,\n signer: Ed25519Keypair,\n sentinelId: string,\n prompt: string,\n feeMist?: bigint,\n): Promise<SentinelAttackResult> {\n const sentinel = await getSentinelInfo(client, sentinelId);\n const fee = feeMist ?? sentinel.attackFee;\n\n if (fee < SENTINEL.MIN_FEE_MIST) {\n throw new T2000Error('INVALID_AMOUNT', `Attack fee must be at least 0.1 SUI`);\n }\n\n const { attackObjectId, digest: requestTx } = await requestAttack(\n client,\n signer,\n sentinel.objectId,\n fee,\n );\n\n const verdict = await submitPrompt(sentinel.id, attackObjectId, prompt);\n\n const { digest: settleTx } = await settleAttack(\n client,\n signer,\n sentinel.objectId,\n attackObjectId,\n prompt,\n verdict,\n );\n\n const won = verdict.success && verdict.score >= 70;\n\n return {\n attackObjectId,\n sentinelId: sentinel.id,\n prompt,\n verdict,\n requestTx,\n settleTx,\n won,\n feePaid: Number(fee) / Number(MIST_PER_SUI),\n };\n}\n","import type {\n LendingAdapter,\n SwapAdapter,\n LendingRates,\n SwapQuote,\n AdapterPositions,\n} from './types.js';\nimport { T2000Error } from '../errors.js';\n\nexport class ProtocolRegistry {\n private lending: Map<string, LendingAdapter> = new Map();\n private swap: Map<string, SwapAdapter> = new Map();\n\n registerLending(adapter: LendingAdapter): void {\n this.lending.set(adapter.id, adapter);\n }\n\n registerSwap(adapter: SwapAdapter): void {\n this.swap.set(adapter.id, adapter);\n }\n\n async bestSaveRate(asset: string): Promise<{ adapter: LendingAdapter; rate: LendingRates }> {\n const candidates: Array<{ adapter: LendingAdapter; rate: LendingRates }> = [];\n\n for (const adapter of this.lending.values()) {\n if (!adapter.supportedAssets.includes(asset)) continue;\n if (!adapter.capabilities.includes('save')) continue;\n try {\n const rate = await adapter.getRates(asset);\n candidates.push({ adapter, rate });\n } catch {\n // skip adapters that fail to fetch rates\n }\n }\n\n if (candidates.length === 0) {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `No lending adapter supports saving ${asset}`);\n }\n\n candidates.sort((a, b) => b.rate.saveApy - a.rate.saveApy);\n return candidates[0];\n }\n\n async bestBorrowRate(asset: string, opts?: { requireSameAssetBorrow?: boolean }): Promise<{ adapter: LendingAdapter; rate: LendingRates }> {\n const candidates: Array<{ adapter: LendingAdapter; rate: LendingRates }> = [];\n\n for (const adapter of this.lending.values()) {\n if (!adapter.supportedAssets.includes(asset)) continue;\n if (!adapter.capabilities.includes('borrow')) continue;\n if (opts?.requireSameAssetBorrow && !adapter.supportsSameAssetBorrow) continue;\n try {\n const rate = await adapter.getRates(asset);\n candidates.push({ adapter, rate });\n } catch {\n // skip\n }\n }\n\n if (candidates.length === 0) {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `No lending adapter supports borrowing ${asset}`);\n }\n\n candidates.sort((a, b) => a.rate.borrowApy - b.rate.borrowApy);\n return candidates[0];\n }\n\n async bestSwapQuote(from: string, to: string, amount: number): Promise<{ adapter: SwapAdapter; quote: SwapQuote }> {\n const candidates: Array<{ adapter: SwapAdapter; quote: SwapQuote }> = [];\n\n for (const adapter of this.swap.values()) {\n const pairs = adapter.getSupportedPairs();\n if (!pairs.some(p => p.from === from && p.to === to)) continue;\n try {\n const quote = await adapter.getQuote(from, to, amount);\n candidates.push({ adapter, quote });\n } catch {\n // skip\n }\n }\n\n if (candidates.length === 0) {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `No swap adapter supports ${from} → ${to}`);\n }\n\n candidates.sort((a, b) => b.quote.expectedOutput - a.quote.expectedOutput);\n return candidates[0];\n }\n\n async allRates(asset: string): Promise<Array<{ protocol: string; protocolId: string; rates: LendingRates }>> {\n const results: Array<{ protocol: string; protocolId: string; rates: LendingRates }> = [];\n for (const adapter of this.lending.values()) {\n if (!adapter.supportedAssets.includes(asset)) continue;\n try {\n const rates = await adapter.getRates(asset);\n results.push({ protocol: adapter.name, protocolId: adapter.id, rates });\n } catch {\n // skip\n }\n }\n return results;\n }\n\n async allPositions(address: string): Promise<Array<{ protocol: string; protocolId: string; positions: AdapterPositions }>> {\n const results: Array<{ protocol: string; protocolId: string; positions: AdapterPositions }> = [];\n for (const adapter of this.lending.values()) {\n try {\n const positions = await adapter.getPositions(address);\n if (positions.supplies.length > 0 || positions.borrows.length > 0) {\n results.push({ protocol: adapter.name, protocolId: adapter.id, positions });\n }\n } catch {\n // skip\n }\n }\n return results;\n }\n\n getLending(id: string): LendingAdapter | undefined {\n return this.lending.get(id);\n }\n\n getSwap(id: string): SwapAdapter | undefined {\n return this.swap.get(id);\n }\n\n listLending(): LendingAdapter[] {\n return [...this.lending.values()];\n }\n\n listSwap(): SwapAdapter[] {\n return [...this.swap.values()];\n }\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type {\n LendingAdapter,\n LendingRates,\n AdapterPositions,\n HealthInfo,\n AdapterTxResult,\n AdapterCapability,\n ProtocolDescriptor,\n} from './types.js';\nimport { T2000Error } from '../errors.js';\nimport * as naviProtocol from '../protocols/navi.js';\n\nexport const descriptor: ProtocolDescriptor = {\n id: 'navi',\n name: 'NAVI Protocol',\n packages: [],\n dynamicPackageId: true,\n actionMap: {\n 'incentive_v3::entry_deposit': 'save',\n 'incentive_v3::deposit': 'save',\n 'incentive_v3::withdraw_v2': 'withdraw',\n 'incentive_v3::entry_withdraw': 'withdraw',\n 'incentive_v3::borrow_v2': 'borrow',\n 'incentive_v3::entry_borrow': 'borrow',\n 'incentive_v3::entry_repay': 'repay',\n 'incentive_v3::repay': 'repay',\n },\n};\n\nexport class NaviAdapter implements LendingAdapter {\n readonly id = 'navi';\n readonly name = 'NAVI Protocol';\n readonly version = '1.0.0';\n readonly capabilities: readonly AdapterCapability[] = ['save', 'withdraw', 'borrow', 'repay'];\n readonly supportedAssets: readonly string[] = ['USDC'];\n readonly supportsSameAssetBorrow = true;\n\n private client!: SuiJsonRpcClient;\n\n async init(client: SuiJsonRpcClient): Promise<void> {\n this.client = client;\n }\n\n initSync(client: SuiJsonRpcClient): void {\n this.client = client;\n }\n\n async getRates(asset: string): Promise<LendingRates> {\n const rates = await naviProtocol.getRates(this.client);\n const key = asset.toUpperCase() as keyof typeof rates;\n const r = rates[key];\n if (!r) throw new T2000Error('ASSET_NOT_SUPPORTED', `NAVI does not support ${asset}`);\n return { asset, saveApy: r.saveApy, borrowApy: r.borrowApy };\n }\n\n async getPositions(address: string): Promise<AdapterPositions> {\n const result = await naviProtocol.getPositions(this.client, address);\n return {\n supplies: result.positions\n .filter(p => p.type === 'save')\n .map(p => ({ asset: p.asset, amount: p.amount, apy: p.apy })),\n borrows: result.positions\n .filter(p => p.type === 'borrow')\n .map(p => ({ asset: p.asset, amount: p.amount, apy: p.apy })),\n };\n }\n\n async getHealth(address: string): Promise<HealthInfo> {\n return naviProtocol.getHealthFactor(this.client, address);\n }\n\n async buildSaveTx(\n address: string,\n amount: number,\n _asset: string,\n options?: { collectFee?: boolean },\n ): Promise<AdapterTxResult> {\n const tx = await naviProtocol.buildSaveTx(this.client, address, amount, options);\n return { tx };\n }\n\n async buildWithdrawTx(\n address: string,\n amount: number,\n _asset: string,\n ): Promise<AdapterTxResult & { effectiveAmount: number }> {\n const result = await naviProtocol.buildWithdrawTx(this.client, address, amount);\n return { tx: result.tx, effectiveAmount: result.effectiveAmount };\n }\n\n async buildBorrowTx(\n address: string,\n amount: number,\n _asset: string,\n options?: { collectFee?: boolean },\n ): Promise<AdapterTxResult> {\n const tx = await naviProtocol.buildBorrowTx(this.client, address, amount, options);\n return { tx };\n }\n\n async buildRepayTx(\n address: string,\n amount: number,\n _asset: string,\n ): Promise<AdapterTxResult> {\n const tx = await naviProtocol.buildRepayTx(this.client, address, amount);\n return { tx };\n }\n\n async maxWithdraw(address: string, _asset: string) {\n return naviProtocol.maxWithdrawAmount(this.client, address);\n }\n\n async maxBorrow(address: string, _asset: string) {\n return naviProtocol.maxBorrowAmount(this.client, address);\n }\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type { Ed25519Keypair } from '@mysten/sui/keypairs/ed25519';\nimport { Transaction } from '@mysten/sui/transactions';\nimport { AggregatorClient, Env } from '@cetusprotocol/aggregator-sdk';\nimport { SUPPORTED_ASSETS, CETUS_USDC_SUI_POOL } from '../constants.js';\nimport { T2000Error } from '../errors.js';\nimport type { GasMethod } from '../types.js';\n\nconst DEFAULT_SLIPPAGE_BPS = 300; // 3%\n\nexport interface SwapParams {\n client: SuiJsonRpcClient;\n keypair: Ed25519Keypair;\n fromAsset: 'USDC' | 'SUI';\n toAsset: 'USDC' | 'SUI';\n amount: number;\n maxSlippageBps?: number;\n}\n\nexport interface SwapTxResult {\n digest: string;\n fromAmount: number;\n fromAsset: string;\n toAmount: number;\n toAsset: string;\n priceImpact: number;\n gasCost: number;\n}\n\nfunction extractGasCost(\n effects: { gasUsed?: { computationCost: string; storageCost: string; storageRebate: string } } | undefined | null,\n): number {\n if (!effects?.gasUsed) return 0;\n return (\n Number(effects.gasUsed.computationCost) +\n Number(effects.gasUsed.storageCost) -\n Number(effects.gasUsed.storageRebate)\n ) / 1e9;\n}\n\nexport interface SwapBuildResult {\n tx: Transaction;\n estimatedOut: number;\n toDecimals: number;\n}\n\nfunction createAggregatorClient(client: SuiJsonRpcClient, signer?: string): AggregatorClient {\n // Cetus SDK bundles @mysten/sui v1 internally — the runtime API is\n // identical to SuiJsonRpcClient, so the cast is safe.\n return new AggregatorClient({\n client: client as never,\n signer,\n env: Env.Mainnet,\n });\n}\n\nexport async function buildSwapTx(params: {\n client: SuiJsonRpcClient;\n address: string;\n fromAsset: 'USDC' | 'SUI';\n toAsset: 'USDC' | 'SUI';\n amount: number;\n maxSlippageBps?: number;\n}): Promise<SwapBuildResult> {\n const { client, address, fromAsset, toAsset, amount, maxSlippageBps = DEFAULT_SLIPPAGE_BPS } = params;\n\n const fromInfo = SUPPORTED_ASSETS[fromAsset];\n const toInfo = SUPPORTED_ASSETS[toAsset];\n const rawAmount = BigInt(Math.floor(amount * 10 ** fromInfo.decimals));\n\n const aggClient = createAggregatorClient(client, address);\n\n const result = await aggClient.findRouters({\n from: fromInfo.type,\n target: toInfo.type,\n amount: rawAmount,\n byAmountIn: true,\n });\n\n if (!result || result.insufficientLiquidity) {\n throw new T2000Error(\n 'ASSET_NOT_SUPPORTED',\n `No swap route found for ${fromAsset} → ${toAsset}`,\n );\n }\n\n const tx = new Transaction();\n const slippage = maxSlippageBps / 10000;\n\n await aggClient.fastRouterSwap({\n router: result,\n txb: tx as never,\n slippage,\n });\n\n const estimatedOut = Number(result.amountOut.toString());\n\n return {\n tx,\n estimatedOut,\n toDecimals: toInfo.decimals,\n };\n}\n\nexport async function executeSwap(params: SwapParams): Promise<SwapTxResult> {\n const { client, keypair, fromAsset, toAsset, amount, maxSlippageBps } = params;\n const address = keypair.getPublicKey().toSuiAddress();\n const toInfo = SUPPORTED_ASSETS[toAsset];\n\n const { tx, estimatedOut, toDecimals } = await buildSwapTx({\n client,\n address,\n fromAsset,\n toAsset,\n amount,\n maxSlippageBps,\n });\n\n const result = await client.signAndExecuteTransaction({\n signer: keypair,\n transaction: tx,\n options: { showEffects: true, showBalanceChanges: true },\n });\n\n await client.waitForTransaction({ digest: result.digest });\n\n let actualReceived = 0;\n if (result.balanceChanges) {\n for (const change of result.balanceChanges) {\n if (\n change.coinType === toInfo.type &&\n change.owner &&\n typeof change.owner === 'object' &&\n 'AddressOwner' in change.owner &&\n change.owner.AddressOwner === address\n ) {\n const amt = Number(change.amount) / 10 ** toInfo.decimals;\n if (amt > 0) actualReceived += amt;\n }\n }\n }\n\n const expectedOutput = estimatedOut / 10 ** toDecimals;\n if (actualReceived === 0) actualReceived = expectedOutput;\n\n const priceImpact = expectedOutput > 0\n ? Math.abs(actualReceived - expectedOutput) / expectedOutput\n : 0;\n\n return {\n digest: result.digest,\n fromAmount: amount,\n fromAsset,\n toAmount: actualReceived,\n toAsset,\n priceImpact,\n gasCost: extractGasCost(result.effects as Parameters<typeof extractGasCost>[0]),\n };\n}\n\nexport async function getPoolPrice(client: SuiJsonRpcClient): Promise<number> {\n try {\n const pool = await client.getObject({\n id: CETUS_USDC_SUI_POOL,\n options: { showContent: true },\n });\n\n if (pool.data?.content?.dataType === 'moveObject') {\n const fields = pool.data.content.fields as Record<string, unknown>;\n const currentSqrtPrice = BigInt(String(fields.current_sqrt_price ?? '0'));\n\n if (currentSqrtPrice > 0n) {\n const Q64 = 2n ** 64n;\n const sqrtPriceFloat = Number(currentSqrtPrice) / Number(Q64);\n const rawPrice = sqrtPriceFloat * sqrtPriceFloat;\n const suiPriceUsd = 1e3 / rawPrice;\n if (suiPriceUsd > 0.01 && suiPriceUsd < 1000) return suiPriceUsd;\n }\n }\n } catch {\n // Fallback\n }\n\n return 3.5;\n}\n\nexport async function getSwapQuote(\n client: SuiJsonRpcClient,\n fromAsset: 'USDC' | 'SUI',\n toAsset: 'USDC' | 'SUI',\n amount: number,\n): Promise<{ expectedOutput: number; priceImpact: number; poolPrice: number }> {\n const fromInfo = SUPPORTED_ASSETS[fromAsset];\n const toInfo = SUPPORTED_ASSETS[toAsset];\n const rawAmount = BigInt(Math.floor(amount * 10 ** fromInfo.decimals));\n\n const poolPrice = await getPoolPrice(client);\n\n try {\n const aggClient = createAggregatorClient(client);\n\n const result = await aggClient.findRouters({\n from: fromInfo.type,\n target: toInfo.type,\n amount: rawAmount,\n byAmountIn: true,\n });\n\n if (!result || result.insufficientLiquidity) {\n return fallbackQuote(fromAsset, amount, poolPrice);\n }\n\n const expectedOutput = Number(result.amountOut.toString()) / 10 ** toInfo.decimals;\n const priceImpact = result.deviationRatio ?? 0;\n\n return { expectedOutput, priceImpact, poolPrice };\n } catch {\n return fallbackQuote(fromAsset, amount, poolPrice);\n }\n}\n\nfunction fallbackQuote(\n fromAsset: string,\n amount: number,\n poolPrice: number,\n): { expectedOutput: number; priceImpact: number; poolPrice: number } {\n const expectedOutput = fromAsset === 'USDC'\n ? amount / poolPrice\n : amount * poolPrice;\n return { expectedOutput, priceImpact: 0, poolPrice };\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type {\n SwapAdapter,\n SwapQuote,\n AdapterTxResult,\n AdapterCapability,\n ProtocolDescriptor,\n} from './types.js';\nimport * as cetusProtocol from '../protocols/cetus.js';\nimport { CETUS_PACKAGE } from '../constants.js';\n\nexport const descriptor: ProtocolDescriptor = {\n id: 'cetus',\n name: 'Cetus DEX',\n packages: [CETUS_PACKAGE],\n actionMap: {\n 'router::swap': 'swap',\n 'router::swap_ab_bc': 'swap',\n 'router::swap_ab_cb': 'swap',\n 'router::swap_ba_bc': 'swap',\n 'router::swap_ba_cb': 'swap',\n },\n};\n\nexport class CetusAdapter implements SwapAdapter {\n readonly id = 'cetus';\n readonly name = 'Cetus';\n readonly version = '1.0.0';\n readonly capabilities: readonly AdapterCapability[] = ['swap'];\n\n private client!: SuiJsonRpcClient;\n\n async init(client: SuiJsonRpcClient): Promise<void> {\n this.client = client;\n }\n\n initSync(client: SuiJsonRpcClient): void {\n this.client = client;\n }\n\n async getQuote(from: string, to: string, amount: number): Promise<SwapQuote> {\n return cetusProtocol.getSwapQuote(\n this.client,\n from.toUpperCase() as 'USDC' | 'SUI',\n to.toUpperCase() as 'USDC' | 'SUI',\n amount,\n );\n }\n\n async buildSwapTx(\n address: string,\n from: string,\n to: string,\n amount: number,\n maxSlippageBps?: number,\n ): Promise<AdapterTxResult & { estimatedOut: number; toDecimals: number }> {\n const result = await cetusProtocol.buildSwapTx({\n client: this.client,\n address,\n fromAsset: from.toUpperCase() as 'USDC' | 'SUI',\n toAsset: to.toUpperCase() as 'USDC' | 'SUI',\n amount,\n maxSlippageBps,\n });\n return {\n tx: result.tx,\n estimatedOut: result.estimatedOut,\n toDecimals: result.toDecimals,\n };\n }\n\n getSupportedPairs(): Array<{ from: string; to: string }> {\n return [\n { from: 'USDC', to: 'SUI' },\n { from: 'SUI', to: 'USDC' },\n ];\n }\n\n async getPoolPrice(): Promise<number> {\n return cetusProtocol.getPoolPrice(this.client);\n }\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport { Transaction } from '@mysten/sui/transactions';\nimport { normalizeStructTag } from '@mysten/sui/utils';\nimport type {\n LendingAdapter,\n LendingRates,\n AdapterPositions,\n HealthInfo,\n AdapterTxResult,\n AdapterCapability,\n ProtocolDescriptor,\n} from './types.js';\nimport { SUPPORTED_ASSETS } from '../constants.js';\nimport { usdcToRaw } from '../utils/format.js';\nimport { T2000Error } from '../errors.js';\nimport { addCollectFeeToTx } from '../protocols/protocolFee.js';\nimport type { TransactionObjectArgument } from '@mysten/sui/transactions';\n\nconst USDC_TYPE = SUPPORTED_ASSETS.USDC.type;\nconst WAD = 1e18;\nconst MIN_HEALTH_FACTOR = 1.5;\nconst CLOCK = '0x6';\n\nconst LENDING_MARKET_ID = '0x84030d26d85eaa7035084a057f2f11f701b7e2e4eda87551becbc7c97505ece1';\nconst LENDING_MARKET_TYPE = '0xf95b06141ed4a174f239417323bde3f209b972f5930d8521ea38a52aff3a6ddf::suilend::MAIN_POOL';\nconst SUILEND_PACKAGE = '0xf95b06141ed4a174f239417323bde3f209b972f5930d8521ea38a52aff3a6ddf';\nconst UPGRADE_CAP_ID = '0x3d4ef1859c3ee9fc72858f588b56a09da5466e64f8cc4e90a7b3b909fba8a7ae';\nconst FALLBACK_PUBLISHED_AT = '0xd2a67633ccb8de063163e25bcfca242929caf5cf1a26c2929dab519ee0b8f331';\n\nexport const descriptor: ProtocolDescriptor = {\n id: 'suilend',\n name: 'Suilend',\n packages: [SUILEND_PACKAGE],\n actionMap: {\n 'lending_market::deposit_liquidity_and_mint_ctokens': 'save',\n 'lending_market::deposit_ctokens_into_obligation': 'save',\n 'lending_market::create_obligation': 'save',\n 'lending_market::withdraw_ctokens': 'withdraw',\n 'lending_market::redeem_ctokens_and_withdraw_liquidity': 'withdraw',\n 'lending_market::borrow': 'borrow',\n 'lending_market::repay': 'repay',\n },\n};\n\ninterface Reserve {\n coinType: string;\n mintDecimals: number;\n availableAmount: number;\n borrowedAmountWad: number;\n ctokenSupply: number;\n unclaimedSpreadFeesWad: number;\n cumulativeBorrowRateWad: number;\n openLtvPct: number;\n closeLtvPct: number;\n spreadFeeBps: number;\n interestRateUtils: number[];\n interestRateAprs: number[];\n arrayIndex: number;\n}\n\ninterface ObligationCap {\n id: string;\n obligationId: string;\n}\n\ninterface Obligation {\n deposits: Array<{ coinType: string; ctokenAmount: number; reserveIdx: number }>;\n borrows: Array<{ coinType: string; borrowedWad: number; cumBorrowRateWad: number; reserveIdx: number }>;\n}\n\n// ---------------------------------------------------------------------------\n// Rate math (unchanged from SDK-based version)\n// ---------------------------------------------------------------------------\n\nfunction interpolateRate(\n utilBreakpoints: number[],\n aprBreakpoints: number[],\n utilizationPct: number,\n): number {\n if (utilBreakpoints.length === 0) return 0;\n if (utilizationPct <= utilBreakpoints[0]) return aprBreakpoints[0];\n if (utilizationPct >= utilBreakpoints[utilBreakpoints.length - 1]) {\n return aprBreakpoints[aprBreakpoints.length - 1];\n }\n\n for (let i = 1; i < utilBreakpoints.length; i++) {\n if (utilizationPct <= utilBreakpoints[i]) {\n const t =\n (utilizationPct - utilBreakpoints[i - 1]) /\n (utilBreakpoints[i] - utilBreakpoints[i - 1]);\n return aprBreakpoints[i - 1] + t * (aprBreakpoints[i] - aprBreakpoints[i - 1]);\n }\n }\n return aprBreakpoints[aprBreakpoints.length - 1];\n}\n\nfunction computeRates(reserve: Reserve): { borrowAprPct: number; depositAprPct: number } {\n const available = reserve.availableAmount / 10 ** reserve.mintDecimals;\n const borrowed = reserve.borrowedAmountWad / WAD / 10 ** reserve.mintDecimals;\n const totalDeposited = available + borrowed;\n const utilizationPct = totalDeposited > 0 ? (borrowed / totalDeposited) * 100 : 0;\n\n if (reserve.interestRateUtils.length === 0) return { borrowAprPct: 0, depositAprPct: 0 };\n\n const aprs = reserve.interestRateAprs.map((a) => a / 100);\n const borrowAprPct = interpolateRate(reserve.interestRateUtils, aprs, utilizationPct);\n const depositAprPct =\n (utilizationPct / 100) *\n (borrowAprPct / 100) *\n (1 - reserve.spreadFeeBps / 10000) *\n 100;\n\n return { borrowAprPct, depositAprPct };\n}\n\nfunction cTokenRatio(reserve: Reserve): number {\n if (reserve.ctokenSupply === 0) return 1;\n const totalSupply =\n reserve.availableAmount +\n reserve.borrowedAmountWad / WAD -\n reserve.unclaimedSpreadFeesWad / WAD;\n return totalSupply / reserve.ctokenSupply;\n}\n\n// ---------------------------------------------------------------------------\n// JSON-RPC response helpers\n// ---------------------------------------------------------------------------\n\ntype Fields = Record<string, unknown>;\n\nfunction f(obj: unknown): Fields {\n if (obj && typeof obj === 'object' && 'fields' in obj) return (obj as { fields: Fields }).fields;\n return obj as Fields;\n}\n\nfunction str(v: unknown): string { return String(v ?? '0'); }\nfunction num(v: unknown): number { return Number(str(v)); }\n\nfunction parseReserve(raw: unknown, index: number): Reserve {\n const r = f(raw);\n const coinTypeField = f(r.coin_type);\n const config = f(f(r.config)?.element);\n\n return {\n coinType: str(coinTypeField?.name),\n mintDecimals: num(r.mint_decimals),\n availableAmount: num(r.available_amount),\n borrowedAmountWad: num(f(r.borrowed_amount)?.value),\n ctokenSupply: num(r.ctoken_supply),\n unclaimedSpreadFeesWad: num(f(r.unclaimed_spread_fees)?.value),\n cumulativeBorrowRateWad: num(f(r.cumulative_borrow_rate)?.value),\n openLtvPct: num(config?.open_ltv_pct),\n closeLtvPct: num(config?.close_ltv_pct),\n spreadFeeBps: num(config?.spread_fee_bps),\n interestRateUtils: Array.isArray(config?.interest_rate_utils) ? (config.interest_rate_utils as unknown[]).map(num) : [],\n interestRateAprs: Array.isArray(config?.interest_rate_aprs) ? (config.interest_rate_aprs as unknown[]).map(num) : [],\n arrayIndex: index,\n };\n}\n\nfunction parseObligation(raw: Fields): Obligation {\n const deposits = Array.isArray(raw.deposits)\n ? (raw.deposits as unknown[]).map((d) => {\n const df = f(d);\n return {\n coinType: str(f(df.coin_type)?.name),\n ctokenAmount: num(df.deposited_ctoken_amount),\n reserveIdx: num(df.reserve_array_index),\n };\n })\n : [];\n\n const borrows = Array.isArray(raw.borrows)\n ? (raw.borrows as unknown[]).map((b) => {\n const bf = f(b);\n return {\n coinType: str(f(bf.coin_type)?.name),\n borrowedWad: num(f(bf.borrowed_amount)?.value),\n cumBorrowRateWad: num(f(bf.cumulative_borrow_rate)?.value),\n reserveIdx: num(bf.reserve_array_index),\n };\n })\n : [];\n\n return { deposits, borrows };\n}\n\n// ---------------------------------------------------------------------------\n// Adapter\n// ---------------------------------------------------------------------------\n\n/**\n * Suilend adapter — contract-first, no SDK dependency.\n * Interacts directly with Suilend Move contracts via RPC + PTB moveCall.\n */\nexport class SuilendAdapter implements LendingAdapter {\n readonly id = 'suilend';\n readonly name = 'Suilend';\n readonly version = '2.0.0';\n readonly capabilities: readonly AdapterCapability[] = ['save', 'withdraw'];\n readonly supportedAssets: readonly string[] = ['USDC'];\n readonly supportsSameAssetBorrow = false;\n\n private client!: SuiJsonRpcClient;\n private publishedAt: string | null = null;\n private reserveCache: Reserve[] | null = null;\n\n async init(client: SuiJsonRpcClient): Promise<void> {\n this.client = client;\n }\n\n initSync(client: SuiJsonRpcClient): void {\n this.client = client;\n }\n\n // -- On-chain reads -------------------------------------------------------\n\n private async resolvePackage(): Promise<string> {\n if (this.publishedAt) return this.publishedAt;\n try {\n const cap = await this.client.getObject({ id: UPGRADE_CAP_ID, options: { showContent: true } });\n if (cap.data?.content?.dataType === 'moveObject') {\n const fields = cap.data.content.fields as Fields;\n this.publishedAt = str(fields.package);\n return this.publishedAt;\n }\n } catch { /* use fallback */ }\n this.publishedAt = FALLBACK_PUBLISHED_AT;\n return this.publishedAt;\n }\n\n private async loadReserves(fresh = false): Promise<Reserve[]> {\n if (this.reserveCache && !fresh) return this.reserveCache;\n\n const market = await this.client.getObject({\n id: LENDING_MARKET_ID,\n options: { showContent: true },\n });\n\n if (market.data?.content?.dataType !== 'moveObject') {\n throw new T2000Error('PROTOCOL_UNAVAILABLE', 'Failed to read Suilend lending market');\n }\n\n const fields = market.data.content.fields as Fields;\n const reservesRaw = fields.reserves as unknown[];\n\n if (!Array.isArray(reservesRaw)) {\n throw new T2000Error('PROTOCOL_UNAVAILABLE', 'Failed to parse Suilend reserves');\n }\n\n this.reserveCache = reservesRaw.map((r, i) => parseReserve(r, i));\n return this.reserveCache;\n }\n\n private findReserve(reserves: Reserve[], asset: string): Reserve | undefined {\n const upper = asset.toUpperCase();\n let coinType: string;\n if (upper === 'USDC') coinType = USDC_TYPE;\n else if (upper === 'SUI') coinType = '0x2::sui::SUI';\n else if (asset.includes('::')) coinType = asset;\n else return undefined;\n\n try {\n const normalized = normalizeStructTag(coinType);\n return reserves.find((r) => {\n try { return normalizeStructTag(r.coinType) === normalized; } catch { return false; }\n });\n } catch { return undefined; }\n }\n\n private async fetchObligationCaps(address: string): Promise<ObligationCap[]> {\n const capType = `${SUILEND_PACKAGE}::lending_market::ObligationOwnerCap<${LENDING_MARKET_TYPE}>`;\n const caps: ObligationCap[] = [];\n let cursor: string | null | undefined;\n let hasNext = true;\n\n while (hasNext) {\n const page = await this.client.getOwnedObjects({\n owner: address,\n filter: { StructType: capType },\n options: { showContent: true },\n cursor: cursor ?? undefined,\n });\n\n for (const item of page.data) {\n if (item.data?.content?.dataType !== 'moveObject') continue;\n const fields = item.data.content.fields as Fields;\n caps.push({\n id: item.data.objectId,\n obligationId: str(fields.obligation_id),\n });\n }\n\n cursor = page.nextCursor;\n hasNext = page.hasNextPage;\n }\n\n return caps;\n }\n\n private async fetchObligation(obligationId: string): Promise<Obligation> {\n const obj = await this.client.getObject({ id: obligationId, options: { showContent: true } });\n if (obj.data?.content?.dataType !== 'moveObject') {\n throw new T2000Error('PROTOCOL_UNAVAILABLE', 'Failed to read Suilend obligation');\n }\n return parseObligation(obj.data.content.fields as Fields);\n }\n\n private resolveSymbol(coinType: string): string {\n try {\n const normalized = normalizeStructTag(coinType);\n if (normalized === normalizeStructTag(USDC_TYPE)) return 'USDC';\n if (normalized === normalizeStructTag('0x2::sui::SUI')) return 'SUI';\n } catch { /* fall through */ }\n const parts = coinType.split('::');\n return parts[parts.length - 1] || 'UNKNOWN';\n }\n\n // -- Adapter interface ----------------------------------------------------\n\n async getRates(asset: string): Promise<LendingRates> {\n const reserves = await this.loadReserves();\n const reserve = this.findReserve(reserves, asset);\n if (!reserve) throw new T2000Error('ASSET_NOT_SUPPORTED', `Suilend does not support ${asset}`);\n\n const { borrowAprPct, depositAprPct } = computeRates(reserve);\n return { asset, saveApy: depositAprPct, borrowApy: borrowAprPct };\n }\n\n async getPositions(address: string): Promise<AdapterPositions> {\n const supplies: Array<{ asset: string; amount: number; apy: number }> = [];\n const borrows: Array<{ asset: string; amount: number; apy: number }> = [];\n\n const caps = await this.fetchObligationCaps(address);\n if (caps.length === 0) return { supplies, borrows };\n\n const [reserves, obligation] = await Promise.all([\n this.loadReserves(),\n this.fetchObligation(caps[0].obligationId),\n ]);\n\n for (const dep of obligation.deposits) {\n const reserve = reserves[dep.reserveIdx];\n if (!reserve) continue;\n const ratio = cTokenRatio(reserve);\n const amount = (dep.ctokenAmount * ratio) / 10 ** reserve.mintDecimals;\n const { depositAprPct } = computeRates(reserve);\n supplies.push({ asset: this.resolveSymbol(dep.coinType), amount, apy: depositAprPct });\n }\n\n for (const bor of obligation.borrows) {\n const reserve = reserves[bor.reserveIdx];\n if (!reserve) continue;\n const rawAmount = bor.borrowedWad / WAD / 10 ** reserve.mintDecimals;\n const reserveRate = reserve.cumulativeBorrowRateWad / WAD;\n const posRate = bor.cumBorrowRateWad / WAD;\n const compounded = posRate > 0 ? rawAmount * (reserveRate / posRate) : rawAmount;\n const { borrowAprPct } = computeRates(reserve);\n borrows.push({ asset: this.resolveSymbol(bor.coinType), amount: compounded, apy: borrowAprPct });\n }\n\n return { supplies, borrows };\n }\n\n async getHealth(address: string): Promise<HealthInfo> {\n const caps = await this.fetchObligationCaps(address);\n if (caps.length === 0) {\n return { healthFactor: Infinity, supplied: 0, borrowed: 0, maxBorrow: 0, liquidationThreshold: 0 };\n }\n\n const positions = await this.getPositions(address);\n const supplied = positions.supplies.reduce((s, p) => s + p.amount, 0);\n const borrowed = positions.borrows.reduce((s, p) => s + p.amount, 0);\n\n const reserves = await this.loadReserves();\n const reserve = this.findReserve(reserves, 'USDC');\n const closeLtv = reserve?.closeLtvPct ?? 75;\n const openLtv = reserve?.openLtvPct ?? 70;\n const liqThreshold = closeLtv / 100;\n\n const healthFactor = borrowed > 0 ? (supplied * liqThreshold) / borrowed : Infinity;\n const maxBorrow = Math.max(0, supplied * (openLtv / 100) - borrowed);\n\n return { healthFactor, supplied, borrowed, maxBorrow, liquidationThreshold: liqThreshold };\n }\n\n async buildSaveTx(\n address: string,\n amount: number,\n _asset: string,\n options?: { collectFee?: boolean },\n ): Promise<AdapterTxResult> {\n const [pkg, reserves] = await Promise.all([this.resolvePackage(), this.loadReserves()]);\n const usdcReserve = this.findReserve(reserves, 'USDC');\n if (!usdcReserve) throw new T2000Error('ASSET_NOT_SUPPORTED', 'USDC reserve not found on Suilend');\n\n const caps = await this.fetchObligationCaps(address);\n const tx = new Transaction();\n tx.setSender(address);\n\n let capRef: TransactionObjectArgument | string;\n if (caps.length === 0) {\n const [newCap] = tx.moveCall({\n target: `${pkg}::lending_market::create_obligation`,\n typeArguments: [LENDING_MARKET_TYPE],\n arguments: [tx.object(LENDING_MARKET_ID)],\n });\n capRef = newCap;\n } else {\n capRef = caps[0].id;\n }\n\n const allCoins = await this.fetchAllCoins(address, USDC_TYPE);\n if (allCoins.length === 0) throw new T2000Error('INSUFFICIENT_BALANCE', 'No USDC coins found');\n\n const primaryCoinId = allCoins[0].coinObjectId;\n if (allCoins.length > 1) {\n tx.mergeCoins(tx.object(primaryCoinId), allCoins.slice(1).map((c) => tx.object(c.coinObjectId)));\n }\n\n const rawAmount = usdcToRaw(amount).toString();\n const [depositCoin] = tx.splitCoins(tx.object(primaryCoinId), [rawAmount]);\n\n if (options?.collectFee) {\n addCollectFeeToTx(tx, depositCoin as TransactionObjectArgument, 'save');\n }\n\n const [ctokens] = tx.moveCall({\n target: `${pkg}::lending_market::deposit_liquidity_and_mint_ctokens`,\n typeArguments: [LENDING_MARKET_TYPE, USDC_TYPE],\n arguments: [\n tx.object(LENDING_MARKET_ID),\n tx.pure.u64(usdcReserve.arrayIndex),\n tx.object(CLOCK),\n depositCoin,\n ],\n });\n\n tx.moveCall({\n target: `${pkg}::lending_market::deposit_ctokens_into_obligation`,\n typeArguments: [LENDING_MARKET_TYPE, USDC_TYPE],\n arguments: [\n tx.object(LENDING_MARKET_ID),\n tx.pure.u64(usdcReserve.arrayIndex),\n typeof capRef === 'string' ? tx.object(capRef) : capRef,\n tx.object(CLOCK),\n ctokens,\n ],\n });\n\n if (typeof capRef !== 'string') {\n tx.transferObjects([capRef], address);\n }\n\n return { tx };\n }\n\n async buildWithdrawTx(\n address: string,\n amount: number,\n _asset: string,\n ): Promise<AdapterTxResult & { effectiveAmount: number }> {\n const [pkg, reserves] = await Promise.all([this.resolvePackage(), this.loadReserves(true)]);\n const usdcReserve = this.findReserve(reserves, 'USDC');\n if (!usdcReserve) throw new T2000Error('ASSET_NOT_SUPPORTED', 'USDC reserve not found on Suilend');\n\n const caps = await this.fetchObligationCaps(address);\n if (caps.length === 0) throw new T2000Error('NO_COLLATERAL', 'No Suilend position found');\n\n const positions = await this.getPositions(address);\n const deposited = positions.supplies.find((s) => s.asset === 'USDC')?.amount ?? 0;\n const effectiveAmount = Math.min(amount, deposited);\n if (effectiveAmount <= 0) throw new T2000Error('NO_COLLATERAL', 'Nothing to withdraw from Suilend');\n\n const ratio = cTokenRatio(usdcReserve);\n const ctokenAmount = Math.ceil(effectiveAmount * 10 ** usdcReserve.mintDecimals / ratio);\n\n const tx = new Transaction();\n tx.setSender(address);\n\n const [ctokens] = tx.moveCall({\n target: `${pkg}::lending_market::withdraw_ctokens`,\n typeArguments: [LENDING_MARKET_TYPE, USDC_TYPE],\n arguments: [\n tx.object(LENDING_MARKET_ID),\n tx.pure.u64(usdcReserve.arrayIndex),\n tx.object(caps[0].id),\n tx.object(CLOCK),\n tx.pure.u64(ctokenAmount),\n ],\n });\n\n const exemptionType = `${SUILEND_PACKAGE}::lending_market::RateLimiterExemption<${LENDING_MARKET_TYPE}, ${USDC_TYPE}>`;\n const [none] = tx.moveCall({\n target: '0x1::option::none',\n typeArguments: [exemptionType],\n });\n\n const [coin] = tx.moveCall({\n target: `${pkg}::lending_market::redeem_ctokens_and_withdraw_liquidity`,\n typeArguments: [LENDING_MARKET_TYPE, USDC_TYPE],\n arguments: [\n tx.object(LENDING_MARKET_ID),\n tx.pure.u64(usdcReserve.arrayIndex),\n tx.object(CLOCK),\n ctokens,\n none,\n ],\n });\n\n tx.transferObjects([coin], address);\n\n return { tx, effectiveAmount };\n }\n\n async buildBorrowTx(\n _address: string,\n _amount: number,\n _asset: string,\n _options?: { collectFee?: boolean },\n ): Promise<AdapterTxResult> {\n throw new T2000Error('ASSET_NOT_SUPPORTED', 'Suilend borrow requires different collateral/borrow assets. Deferred to Phase 10.');\n }\n\n async buildRepayTx(\n _address: string,\n _amount: number,\n _asset: string,\n ): Promise<AdapterTxResult> {\n throw new T2000Error('ASSET_NOT_SUPPORTED', 'Suilend repay deferred to Phase 10.');\n }\n\n async maxWithdraw(\n address: string,\n _asset: string,\n ): Promise<{ maxAmount: number; healthFactorAfter: number; currentHF: number }> {\n const health = await this.getHealth(address);\n\n let maxAmount: number;\n if (health.borrowed === 0) {\n maxAmount = health.supplied;\n } else {\n maxAmount = Math.max(0, health.supplied - (health.borrowed * MIN_HEALTH_FACTOR) / health.liquidationThreshold);\n }\n\n const remainingSupply = health.supplied - maxAmount;\n const hfAfter = health.borrowed > 0\n ? (remainingSupply * health.liquidationThreshold) / health.borrowed\n : Infinity;\n\n return { maxAmount, healthFactorAfter: hfAfter, currentHF: health.healthFactor };\n }\n\n async maxBorrow(\n _address: string,\n _asset: string,\n ): Promise<{ maxAmount: number; healthFactorAfter: number; currentHF: number }> {\n throw new T2000Error('ASSET_NOT_SUPPORTED', 'Suilend maxBorrow deferred to Phase 10.');\n }\n\n private async fetchAllCoins(\n owner: string,\n coinType: string,\n ): Promise<Array<{ coinObjectId: string; balance: string }>> {\n const all: Array<{ coinObjectId: string; balance: string }> = [];\n let cursor: string | null | undefined = null;\n let hasNext = true;\n\n while (hasNext) {\n const page = await this.client.getCoins({ owner, coinType, cursor: cursor ?? undefined });\n all.push(...page.data.map((c) => ({ coinObjectId: c.coinObjectId, balance: c.balance })));\n cursor = page.nextCursor;\n hasNext = page.hasNextPage;\n }\n\n return all;\n }\n}\n","import { createHash } from 'node:crypto';\n\nfunction hasLeadingZeroBits(hash: Buffer, bits: number): boolean {\n const fullBytes = Math.floor(bits / 8);\n const remainingBits = bits % 8;\n\n for (let i = 0; i < fullBytes; i++) {\n if (hash[i] !== 0) return false;\n }\n\n if (remainingBits > 0) {\n const mask = 0xff << (8 - remainingBits);\n if ((hash[fullBytes] & mask) !== 0) return false;\n }\n\n return true;\n}\n\nexport function solveHashcash(challenge: string): string {\n const bits = parseInt(challenge.split(':')[1], 10);\n let counter = 0;\n while (true) {\n const stamp = `${challenge}${counter.toString(16)}`;\n const hash = createHash('sha256').update(stamp).digest();\n if (hasLeadingZeroBits(hash, bits)) return stamp;\n counter++;\n }\n}\n","import { API_BASE_URL } from '../constants.js';\nimport { T2000Error } from '../errors.js';\n\nexport type GasRequestType = 'bootstrap' | 'auto-topup' | 'fallback';\n\nexport interface GasSponsorResponse {\n txBytes: string;\n sponsorSignature: string;\n gasEstimateUsd: number;\n type: GasRequestType;\n}\n\nexport interface GasStatusResponse {\n circuitBreaker: boolean;\n suiPrice: number;\n bootstrapUsed?: number;\n bootstrapRemaining?: number;\n}\n\n/**\n * Request gas sponsorship from the gas station.\n *\n * Sends both `txJson` (preferred, v0.2.0+ server) and `txBytes` (base64-encoded\n * JSON for backward compat with v0.1.9 server). The server uses whichever field\n * it understands.\n */\nexport async function requestGasSponsorship(\n txJson: string,\n sender: string,\n type?: GasRequestType,\n): Promise<GasSponsorResponse> {\n const txBytes = Buffer.from(txJson).toString('base64');\n\n const res = await fetch(`${API_BASE_URL}/api/gas`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ txJson, txBytes, sender, type }),\n });\n\n const data = (await res.json()) as Record<string, unknown>;\n\n if (!res.ok) {\n const errorCode = data.error as string;\n\n if (errorCode === 'CIRCUIT_BREAKER' || errorCode === 'POOL_DEPLETED') {\n throw new T2000Error(\n 'GAS_STATION_UNAVAILABLE',\n (data.message as string) ?? 'Gas station temporarily unavailable',\n { retryAfter: data.retryAfter },\n true,\n );\n }\n if (errorCode === 'GAS_FEE_EXCEEDED') {\n throw new T2000Error(\n 'GAS_FEE_EXCEEDED',\n (data.message as string) ?? 'Gas fee exceeds ceiling',\n { retryAfter: data.retryAfter },\n true,\n );\n }\n\n throw new T2000Error(\n 'GAS_STATION_UNAVAILABLE',\n (data.message as string) ?? 'Gas sponsorship request failed',\n undefined,\n true,\n );\n }\n\n return data as unknown as GasSponsorResponse;\n}\n\nexport async function reportGasUsage(\n sender: string,\n txDigest: string,\n gasCostSui: number,\n usdcCharged: number,\n type: GasRequestType,\n): Promise<void> {\n try {\n await fetch(`${API_BASE_URL}/api/gas/report`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ sender, txDigest, gasCostSui, usdcCharged, type }),\n });\n } catch {\n // Non-critical — best-effort reporting\n }\n}\n\nexport async function getGasStatus(address?: string): Promise<GasStatusResponse> {\n const url = new URL(`${API_BASE_URL}/api/gas/status`);\n if (address) url.searchParams.set('address', address);\n\n const res = await fetch(url.toString());\n if (!res.ok) {\n throw new T2000Error('GAS_STATION_UNAVAILABLE', 'Failed to fetch gas status', undefined, true);\n }\n\n return (await res.json()) as GasStatusResponse;\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type { Ed25519Keypair } from '@mysten/sui/keypairs/ed25519';\nimport {\n SUPPORTED_ASSETS,\n AUTO_TOPUP_THRESHOLD,\n AUTO_TOPUP_AMOUNT,\n AUTO_TOPUP_MIN_USDC,\n MIST_PER_SUI,\n} from '../constants.js';\nimport { T2000Error } from '../errors.js';\nimport { buildSwapTx } from '../protocols/cetus.js';\nimport { requestGasSponsorship, reportGasUsage } from './gasStation.js';\n\nexport interface AutoTopUpResult {\n success: boolean;\n tx: string;\n usdcSpent: number;\n suiReceived: number;\n}\n\nexport async function shouldAutoTopUp(\n client: SuiJsonRpcClient,\n address: string,\n): Promise<boolean> {\n const [suiBalance, usdcBalance] = await Promise.all([\n client.getBalance({ owner: address, coinType: SUPPORTED_ASSETS.SUI.type }),\n client.getBalance({ owner: address, coinType: SUPPORTED_ASSETS.USDC.type }),\n ]);\n\n const suiRaw = BigInt(suiBalance.totalBalance);\n const usdcRaw = BigInt(usdcBalance.totalBalance);\n\n return suiRaw < AUTO_TOPUP_THRESHOLD && usdcRaw >= AUTO_TOPUP_MIN_USDC;\n}\n\nexport async function executeAutoTopUp(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n): Promise<AutoTopUpResult> {\n const address = keypair.getPublicKey().toSuiAddress();\n const topupAmountHuman = Number(AUTO_TOPUP_AMOUNT) / 1e6; // $1 USDC\n\n // Build swap tx via Cetus SDK (handles package upgrades automatically)\n const { tx } = await buildSwapTx({\n client,\n address,\n fromAsset: 'USDC',\n toAsset: 'SUI',\n amount: topupAmountHuman,\n });\n\n const txJson = tx.serialize();\n const sponsoredResult = await requestGasSponsorship(txJson, address, 'auto-topup');\n\n // Sign with agent key and submit\n const sponsoredTxBytes = Buffer.from(sponsoredResult.txBytes, 'base64');\n const { signature: agentSig } = await keypair.signTransaction(sponsoredTxBytes);\n\n const result = await client.executeTransactionBlock({\n transactionBlock: sponsoredResult.txBytes,\n signature: [agentSig, sponsoredResult.sponsorSignature],\n options: { showEffects: true, showBalanceChanges: true },\n });\n\n await client.waitForTransaction({ digest: result.digest });\n\n let suiReceived = 0;\n if (result.balanceChanges) {\n for (const change of result.balanceChanges) {\n if (\n change.coinType === SUPPORTED_ASSETS.SUI.type &&\n change.owner &&\n typeof change.owner === 'object' &&\n 'AddressOwner' in change.owner &&\n change.owner.AddressOwner === address\n ) {\n suiReceived += Number(change.amount) / Number(MIST_PER_SUI);\n }\n }\n }\n\n reportGasUsage(address, result.digest, 0, 0, 'auto-topup');\n\n return {\n success: true,\n tx: result.digest,\n usdcSpent: topupAmountHuman,\n suiReceived: Math.abs(suiReceived),\n };\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type { Ed25519Keypair } from '@mysten/sui/keypairs/ed25519';\nimport { Transaction } from '@mysten/sui/transactions';\nimport {\n SUPPORTED_ASSETS,\n AUTO_TOPUP_THRESHOLD,\n MIST_PER_SUI,\n} from '../constants.js';\nimport type { GasMethod } from '../types.js';\nimport { T2000Error } from '../errors.js';\nimport { shouldAutoTopUp, executeAutoTopUp } from './autoTopUp.js';\nimport { requestGasSponsorship, reportGasUsage } from './gasStation.js';\n\nexport interface GasExecutionResult {\n digest: string;\n effects: unknown;\n gasMethod: GasMethod;\n gasCostSui: number;\n}\n\nfunction extractGasCost(\n effects: { gasUsed?: { computationCost: string; storageCost: string; storageRebate: string } } | undefined | null,\n): number {\n if (!effects?.gasUsed) return 0;\n return (\n Number(effects.gasUsed.computationCost) +\n Number(effects.gasUsed.storageCost) -\n Number(effects.gasUsed.storageRebate)\n ) / 1e9;\n}\n\nasync function getSuiBalance(client: SuiJsonRpcClient, address: string): Promise<bigint> {\n const bal = await client.getBalance({ owner: address, coinType: SUPPORTED_ASSETS.SUI.type });\n return BigInt(bal.totalBalance);\n}\n\nasync function trySelfFunded(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n tx: Transaction,\n): Promise<GasExecutionResult | null> {\n const address = keypair.getPublicKey().toSuiAddress();\n const suiBalance = await getSuiBalance(client, address);\n\n // Need at least 0.05 SUI for gas\n if (suiBalance < AUTO_TOPUP_THRESHOLD) return null;\n\n tx.setSender(address);\n\n const result = await client.signAndExecuteTransaction({\n signer: keypair,\n transaction: tx,\n options: { showEffects: true },\n });\n await client.waitForTransaction({ digest: result.digest });\n\n return {\n digest: result.digest,\n effects: result.effects,\n gasMethod: 'self-funded',\n gasCostSui: extractGasCost(result.effects as Parameters<typeof extractGasCost>[0]),\n };\n}\n\nasync function tryAutoTopUpThenSelfFund(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n tx: Transaction,\n): Promise<GasExecutionResult | null> {\n const address = keypair.getPublicKey().toSuiAddress();\n\n const canTopUp = await shouldAutoTopUp(client, address);\n if (!canTopUp) return null;\n\n // Let errors propagate so executeWithGas captures the real reason\n await executeAutoTopUp(client, keypair);\n\n // After top-up, try self-funded again\n tx.setSender(address);\n\n const result = await client.signAndExecuteTransaction({\n signer: keypair,\n transaction: tx,\n options: { showEffects: true },\n });\n await client.waitForTransaction({ digest: result.digest });\n\n return {\n digest: result.digest,\n effects: result.effects,\n gasMethod: 'auto-topup',\n gasCostSui: extractGasCost(result.effects as Parameters<typeof extractGasCost>[0]),\n };\n}\n\nasync function trySponsored(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n tx: Transaction,\n): Promise<GasExecutionResult | null> {\n const address = keypair.getPublicKey().toSuiAddress();\n tx.setSender(address);\n\n const txJson = tx.serialize();\n const sponsoredResult = await requestGasSponsorship(txJson, address);\n\n const sponsoredTxBytes = Buffer.from(sponsoredResult.txBytes, 'base64');\n const { signature: agentSig } = await keypair.signTransaction(sponsoredTxBytes);\n\n const result = await client.executeTransactionBlock({\n transactionBlock: sponsoredResult.txBytes,\n signature: [agentSig, sponsoredResult.sponsorSignature],\n options: { showEffects: true },\n });\n\n await client.waitForTransaction({ digest: result.digest });\n\n // Report gas usage (best-effort)\n const gasCost = extractGasCost(result.effects as Parameters<typeof extractGasCost>[0]);\n reportGasUsage(address, result.digest, gasCost, 0, sponsoredResult.type);\n\n return {\n digest: result.digest,\n effects: result.effects,\n gasMethod: 'sponsored',\n gasCostSui: gasCost,\n };\n}\n\n/**\n * Gas resolution chain:\n * 1. Self-funded (agent has enough SUI)\n * 2. Auto-topup (swap USDC→SUI, then self-fund)\n * 3. Gas Station sponsored (fallback)\n * 4. Fail with INSUFFICIENT_GAS\n */\nexport async function executeWithGas(\n client: SuiJsonRpcClient,\n keypair: Ed25519Keypair,\n buildTx: () => Transaction | Promise<Transaction>,\n): Promise<GasExecutionResult> {\n const errors: string[] = [];\n\n // Step 1: Try self-funded\n try {\n const tx = await buildTx();\n const result = await trySelfFunded(client, keypair, tx);\n if (result) return result;\n errors.push('self-funded: SUI below threshold');\n } catch (err) {\n errors.push(`self-funded: ${err instanceof Error ? err.message : String(err)}`);\n }\n\n // Step 2: Try auto-topup then self-fund\n try {\n const tx = await buildTx();\n const result = await tryAutoTopUpThenSelfFund(client, keypair, tx);\n if (result) return result;\n errors.push('auto-topup: not eligible (low USDC or sufficient SUI)');\n } catch (err) {\n errors.push(`auto-topup: ${err instanceof Error ? err.message : String(err)}`);\n }\n\n // Step 3: Try gas station sponsored\n try {\n const tx = await buildTx();\n const result = await trySponsored(client, keypair, tx);\n if (result) return result;\n errors.push('sponsored: returned null');\n } catch (err) {\n errors.push(`sponsored: ${err instanceof Error ? err.message : String(err)}`);\n }\n\n // Step 4: All methods failed\n throw new T2000Error(\n 'INSUFFICIENT_GAS',\n `No SUI for gas and Gas Station unavailable. Fund your wallet with SUI or USDC. [${errors.join(' | ')}]`,\n { reason: 'all_gas_methods_exhausted', errors },\n );\n}\n","import { EventEmitter } from 'eventemitter3';\nimport type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport type { Ed25519Keypair } from '@mysten/sui/keypairs/ed25519';\nimport { getSuiClient } from './utils/sui.js';\nimport {\n generateKeypair,\n keypairFromPrivateKey,\n saveKey,\n loadKey,\n walletExists,\n exportPrivateKey,\n getAddress,\n} from './wallet/keyManager.js';\nimport { buildSendTx } from './wallet/send.js';\nimport { queryBalance } from './wallet/balance.js';\nimport { queryHistory } from './wallet/history.js';\nimport { calculateFee, reportFee } from './protocols/protocolFee.js';\nimport * as yieldTracker from './protocols/yieldTracker.js';\nimport * as sentinel from './protocols/sentinel.js';\nimport { ProtocolRegistry } from './adapters/registry.js';\nimport { NaviAdapter } from './adapters/navi.js';\nimport { CetusAdapter } from './adapters/cetus.js';\nimport { SuilendAdapter } from './adapters/suilend.js';\nimport type { LendingAdapter, SwapAdapter } from './adapters/types.js';\nimport { solveHashcash } from './utils/hashcash.js';\nimport { executeWithGas } from './gas/manager.js';\nimport type {\n T2000Options,\n BalanceResponse,\n SendResult,\n SaveResult,\n WithdrawResult,\n BorrowResult,\n RepayResult,\n SwapResult,\n HealthFactorResult,\n MaxWithdrawResult,\n MaxBorrowResult,\n RatesResult,\n PositionsResult,\n TransactionRecord,\n DepositInfo,\n EarningsResult,\n FundStatusResult,\n SentinelAgent,\n SentinelAttackResult,\n} from './types.js';\nimport { T2000Error } from './errors.js';\nimport { SUPPORTED_ASSETS, DEFAULT_NETWORK, API_BASE_URL } from './constants.js';\nimport { truncateAddress } from './utils/sui.js';\n\ninterface T2000Events {\n balanceChange: (event: { asset: string; previous: number; current: number; cause: string; tx?: string }) => void;\n healthWarning: (event: { healthFactor: number; threshold: number; severity: 'warning' }) => void;\n healthCritical: (event: { healthFactor: number; threshold: number; severity: 'critical' }) => void;\n yield: (event: { earned: number; total: number; apy: number; timestamp: number }) => void;\n gasAutoTopUp: (result: { usdcSpent: number; suiReceived: number }) => void;\n gasStationFallback: (event: { reason: string; method: string; suiUsed: number }) => void;\n error: (error: T2000Error) => void;\n}\n\nexport class T2000 extends EventEmitter<T2000Events> {\n private readonly keypair: Ed25519Keypair;\n private readonly client: SuiJsonRpcClient;\n private readonly _address: string;\n private readonly registry: ProtocolRegistry;\n\n private constructor(keypair: Ed25519Keypair, client: SuiJsonRpcClient, registry?: ProtocolRegistry) {\n super();\n this.keypair = keypair;\n this.client = client;\n this._address = getAddress(keypair);\n this.registry = registry ?? T2000.createDefaultRegistry(client);\n }\n\n private static createDefaultRegistry(client: SuiJsonRpcClient): ProtocolRegistry {\n const registry = new ProtocolRegistry();\n const naviAdapter = new NaviAdapter();\n naviAdapter.initSync(client);\n registry.registerLending(naviAdapter);\n const cetusAdapter = new CetusAdapter();\n cetusAdapter.initSync(client);\n registry.registerSwap(cetusAdapter);\n const suilendAdapter = new SuilendAdapter();\n suilendAdapter.initSync(client);\n registry.registerLending(suilendAdapter);\n return registry;\n }\n\n static async create(options: T2000Options = {}): Promise<T2000> {\n const { keyPath, pin, passphrase, network = DEFAULT_NETWORK, rpcUrl, sponsored, name } = options;\n const secret = pin ?? passphrase;\n\n const client = getSuiClient(rpcUrl);\n\n if (sponsored) {\n const keypair = generateKeypair();\n if (secret) {\n await saveKey(keypair, secret, keyPath);\n }\n return new T2000(keypair, client);\n }\n\n const exists = await walletExists(keyPath);\n if (!exists) {\n throw new T2000Error(\n 'WALLET_NOT_FOUND',\n 'No wallet found. Run `t2000 init` to create one.',\n );\n }\n\n if (!secret) {\n throw new T2000Error('WALLET_LOCKED', 'PIN required to unlock wallet');\n }\n\n const keypair = await loadKey(secret, keyPath);\n return new T2000(keypair, client);\n }\n\n static fromPrivateKey(privateKey: string, options: { network?: 'mainnet' | 'testnet'; rpcUrl?: string } = {}): T2000 {\n const keypair = keypairFromPrivateKey(privateKey);\n const client = getSuiClient(options.rpcUrl);\n return new T2000(keypair, client);\n }\n\n static async init(options: { pin: string; passphrase?: string; keyPath?: string; name?: string; sponsored?: boolean }): Promise<{ agent: T2000; address: string; sponsored: boolean }> {\n const secret = options.pin ?? options.passphrase ?? '';\n const keypair = generateKeypair();\n await saveKey(keypair, secret, options.keyPath);\n\n const client = getSuiClient();\n const agent = new T2000(keypair, client);\n const address = agent.address();\n\n let sponsored = false;\n if (options.sponsored !== false) {\n try {\n await callSponsorApi(address, options.name);\n sponsored = true;\n } catch {\n // Sponsor unavailable — agent can still be funded manually\n }\n }\n\n return { agent, address, sponsored };\n }\n\n // -- Gas --\n\n /** SuiJsonRpcClient used by this agent — exposed for x402 and other integrations. */\n get suiClient(): SuiJsonRpcClient {\n return this.client;\n }\n\n /** Ed25519Keypair used by this agent — exposed for x402 and other integrations. */\n get signer(): Ed25519Keypair {\n return this.keypair;\n }\n\n // -- Wallet --\n\n address(): string {\n return this._address;\n }\n\n async send(params: { to: string; amount: number; asset?: string }): Promise<SendResult> {\n const asset = (params.asset ?? 'USDC') as keyof typeof SUPPORTED_ASSETS;\n if (!(asset in SUPPORTED_ASSETS)) {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `Asset ${asset} is not supported`);\n }\n\n const sendAmount = params.amount;\n const sendTo = params.to;\n\n const gasResult = await executeWithGas(this.client, this.keypair, () =>\n buildSendTx({ client: this.client, address: this._address, to: sendTo, amount: sendAmount, asset }),\n );\n\n const balance = await this.balance();\n\n this.emitBalanceChange(asset, sendAmount, 'send', gasResult.digest);\n\n return {\n success: true,\n tx: gasResult.digest,\n amount: sendAmount,\n to: params.to,\n gasCost: gasResult.gasCostSui,\n gasCostUnit: 'SUI',\n gasMethod: gasResult.gasMethod,\n balance,\n };\n }\n\n async balance(): Promise<BalanceResponse> {\n const bal = await queryBalance(this.client, this._address);\n\n try {\n const positions = await this.positions();\n const savings = positions.positions\n .filter((p) => p.type === 'save')\n .reduce((sum, p) => sum + p.amount, 0);\n bal.savings = savings;\n bal.total = bal.available + savings + bal.gasReserve.usdEquiv;\n } catch {\n // NAVI unavailable — show basic balance\n }\n\n return bal;\n }\n\n async history(params?: { limit?: number }): Promise<TransactionRecord[]> {\n return queryHistory(this.client, this._address, params?.limit);\n }\n\n async deposit(): Promise<DepositInfo> {\n return {\n address: this._address,\n network: 'Sui (mainnet)',\n supportedAssets: ['USDC'],\n instructions: [\n `Send USDC on Sui to: ${this._address}`,\n '',\n 'From a CEX (Coinbase, Binance):',\n ` 1. Withdraw USDC`,\n ` 2. Select \"Sui\" network`,\n ` 3. Paste address: ${truncateAddress(this._address)}`,\n '',\n 'From another Sui wallet:',\n ` Transfer USDC to ${truncateAddress(this._address)}`,\n ].join('\\n'),\n };\n }\n\n exportKey(): string {\n return exportPrivateKey(this.keypair);\n }\n\n async registerAdapter(adapter: LendingAdapter | SwapAdapter): Promise<void> {\n await adapter.init(this.client);\n if ('buildSaveTx' in adapter) this.registry.registerLending(adapter as LendingAdapter);\n if ('buildSwapTx' in adapter) this.registry.registerSwap(adapter as SwapAdapter);\n }\n\n // -- Savings --\n\n async save(params: { amount: number | 'all'; asset?: string; protocol?: string }): Promise<SaveResult> {\n const asset = (params.asset ?? 'USDC').toUpperCase();\n if (asset !== 'USDC') {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `Only USDC is supported for save. Got: ${asset}`);\n }\n\n let amount: number;\n if (params.amount === 'all') {\n const bal = await queryBalance(this.client, this._address);\n const GAS_RESERVE_USDC = 1.0;\n amount = bal.available - GAS_RESERVE_USDC;\n if (amount <= 0) {\n throw new T2000Error('INSUFFICIENT_BALANCE', 'Balance too low to save after $1 gas reserve', {\n reason: 'gas_reserve_required',\n available: bal.available,\n });\n }\n } else {\n amount = params.amount;\n }\n const fee = calculateFee('save', amount);\n const saveAmount = amount;\n\n const adapter = await this.resolveLending(params.protocol, asset, 'save');\n\n const gasResult = await executeWithGas(this.client, this.keypair, async () => {\n const { tx } = await adapter.buildSaveTx(this._address, saveAmount, asset, { collectFee: true });\n return tx;\n });\n\n const rates = await adapter.getRates(asset);\n reportFee(this._address, 'save', fee.amount, fee.rate, gasResult.digest);\n this.emitBalanceChange('USDC', saveAmount, 'save', gasResult.digest);\n\n let savingsBalance = saveAmount;\n try {\n const positions = await this.positions();\n savingsBalance = positions.positions\n .filter((p) => p.type === 'save')\n .reduce((sum, p) => sum + p.amount, 0);\n } catch {\n // query failed — fall back to deposit amount\n }\n\n return {\n success: true,\n tx: gasResult.digest,\n amount: saveAmount,\n apy: rates.saveApy,\n fee: fee.amount,\n gasCost: gasResult.gasCostSui,\n gasMethod: gasResult.gasMethod,\n savingsBalance,\n };\n }\n\n async withdraw(params: { amount: number | 'all'; asset?: string; protocol?: string }): Promise<WithdrawResult> {\n const asset = (params.asset ?? 'USDC').toUpperCase();\n if (asset !== 'USDC') {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `Only USDC is supported for withdraw. Got: ${asset}`);\n }\n\n const adapter = await this.resolveLending(params.protocol, asset, 'withdraw');\n\n let amount: number;\n if (params.amount === 'all') {\n const maxResult = await adapter.maxWithdraw(this._address, asset);\n amount = maxResult.maxAmount;\n if (amount <= 0) {\n throw new T2000Error('NO_COLLATERAL', 'No savings to withdraw');\n }\n } else {\n amount = params.amount;\n\n const hf = await adapter.getHealth(this._address);\n if (hf.borrowed > 0) {\n const maxResult = await adapter.maxWithdraw(this._address, asset);\n if (amount > maxResult.maxAmount) {\n throw new T2000Error(\n 'WITHDRAW_WOULD_LIQUIDATE',\n `Withdrawing $${amount.toFixed(2)} would drop health factor below 1.5`,\n {\n safeWithdrawAmount: maxResult.maxAmount,\n currentHF: maxResult.currentHF,\n projectedHF: maxResult.healthFactorAfter,\n },\n );\n }\n }\n }\n const withdrawAmount = amount;\n let effectiveAmount = withdrawAmount;\n\n const gasResult = await executeWithGas(this.client, this.keypair, async () => {\n const built = await adapter.buildWithdrawTx(this._address, withdrawAmount, asset);\n effectiveAmount = built.effectiveAmount;\n return built.tx;\n });\n\n this.emitBalanceChange('USDC', effectiveAmount, 'withdraw', gasResult.digest);\n\n return {\n success: true,\n tx: gasResult.digest,\n amount: effectiveAmount,\n gasCost: gasResult.gasCostSui,\n gasMethod: gasResult.gasMethod,\n };\n }\n\n async maxWithdraw(): Promise<MaxWithdrawResult> {\n const adapter = await this.resolveLending(undefined, 'USDC', 'withdraw');\n return adapter.maxWithdraw(this._address, 'USDC');\n }\n\n // -- Borrowing --\n\n async borrow(params: { amount: number; asset?: string; protocol?: string }): Promise<BorrowResult> {\n const asset = (params.asset ?? 'USDC').toUpperCase();\n if (asset !== 'USDC') {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `Only USDC is supported for borrow. Got: ${asset}`);\n }\n\n const adapter = await this.resolveLending(params.protocol, asset, 'borrow');\n\n const maxResult = await adapter.maxBorrow(this._address, asset);\n if (params.amount > maxResult.maxAmount) {\n throw new T2000Error('HEALTH_FACTOR_TOO_LOW', `Max safe borrow: $${maxResult.maxAmount.toFixed(2)}`, {\n maxBorrow: maxResult.maxAmount,\n currentHF: maxResult.currentHF,\n });\n }\n const fee = calculateFee('borrow', params.amount);\n const borrowAmount = params.amount;\n\n const gasResult = await executeWithGas(this.client, this.keypair, async () => {\n const { tx } = await adapter.buildBorrowTx(this._address, borrowAmount, asset, { collectFee: true });\n return tx;\n });\n\n const hf = await adapter.getHealth(this._address);\n reportFee(this._address, 'borrow', fee.amount, fee.rate, gasResult.digest);\n this.emitBalanceChange('USDC', borrowAmount, 'borrow', gasResult.digest);\n\n return {\n success: true,\n tx: gasResult.digest,\n amount: borrowAmount,\n fee: fee.amount,\n healthFactor: hf.healthFactor,\n gasCost: gasResult.gasCostSui,\n gasMethod: gasResult.gasMethod,\n };\n }\n\n async repay(params: { amount: number | 'all'; asset?: string; protocol?: string }): Promise<RepayResult> {\n const asset = (params.asset ?? 'USDC').toUpperCase();\n if (asset !== 'USDC') {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `Only USDC is supported for repay. Got: ${asset}`);\n }\n\n const adapter = await this.resolveLending(params.protocol, asset, 'repay');\n\n let amount: number;\n if (params.amount === 'all') {\n const hf = await adapter.getHealth(this._address);\n amount = hf.borrowed;\n if (amount <= 0) {\n throw new T2000Error('NO_COLLATERAL', 'No outstanding borrow to repay');\n }\n } else {\n amount = params.amount;\n }\n const repayAmount = amount;\n\n const gasResult = await executeWithGas(this.client, this.keypair, async () => {\n const { tx } = await adapter.buildRepayTx(this._address, repayAmount, asset);\n return tx;\n });\n\n const hf = await adapter.getHealth(this._address);\n this.emitBalanceChange('USDC', repayAmount, 'repay', gasResult.digest);\n\n return {\n success: true,\n tx: gasResult.digest,\n amount: repayAmount,\n remainingDebt: hf.borrowed,\n gasCost: gasResult.gasCostSui,\n gasMethod: gasResult.gasMethod,\n };\n }\n\n async maxBorrow(): Promise<MaxBorrowResult> {\n const adapter = await this.resolveLending(undefined, 'USDC', 'borrow');\n return adapter.maxBorrow(this._address, 'USDC');\n }\n\n async healthFactor(): Promise<HealthFactorResult> {\n const adapter = await this.resolveLending(undefined, 'USDC', 'save');\n const hf = await adapter.getHealth(this._address);\n\n if (hf.healthFactor < 1.2) {\n this.emit('healthCritical', { healthFactor: hf.healthFactor, threshold: 1.5, severity: 'critical' });\n } else if (hf.healthFactor < 2.0) {\n this.emit('healthWarning', { healthFactor: hf.healthFactor, threshold: 2.0, severity: 'warning' });\n }\n\n return hf;\n }\n\n // -- Swap --\n\n async swap(params: { from: string; to: string; amount: number; maxSlippage?: number; protocol?: string }): Promise<SwapResult> {\n const fromAsset = params.from.toUpperCase() as 'USDC' | 'SUI';\n const toAsset = params.to.toUpperCase() as 'USDC' | 'SUI';\n\n if (!(fromAsset in SUPPORTED_ASSETS) || !(toAsset in SUPPORTED_ASSETS)) {\n throw new T2000Error('ASSET_NOT_SUPPORTED', `Swap pair ${fromAsset}/${toAsset} is not supported`);\n }\n if (fromAsset === toAsset) {\n throw new T2000Error('INVALID_AMOUNT', 'Cannot swap same asset');\n }\n\n let adapter: SwapAdapter;\n if (params.protocol) {\n const found = this.registry.getSwap(params.protocol);\n if (!found) throw new T2000Error('ASSET_NOT_SUPPORTED', `Swap adapter '${params.protocol}' not found`);\n adapter = found;\n } else {\n const best = await this.registry.bestSwapQuote(fromAsset, toAsset, params.amount);\n adapter = best.adapter;\n }\n\n const fee = calculateFee('swap', params.amount);\n const swapAmount = params.amount;\n const slippageBps = params.maxSlippage ? params.maxSlippage * 100 : undefined;\n\n let swapMeta: { estimatedOut: number; toDecimals: number } = { estimatedOut: 0, toDecimals: 0 };\n\n const gasResult = await executeWithGas(this.client, this.keypair, async () => {\n const built = await adapter.buildSwapTx(this._address, fromAsset, toAsset, swapAmount, slippageBps);\n swapMeta = { estimatedOut: built.estimatedOut, toDecimals: built.toDecimals };\n return built.tx;\n });\n\n const toInfo = SUPPORTED_ASSETS[toAsset];\n await this.client.waitForTransaction({ digest: gasResult.digest });\n const txDetail = await this.client.getTransactionBlock({\n digest: gasResult.digest,\n options: { showBalanceChanges: true },\n });\n\n let actualReceived = 0;\n if (txDetail.balanceChanges) {\n for (const change of txDetail.balanceChanges) {\n if (\n change.coinType === toInfo.type &&\n change.owner &&\n typeof change.owner === 'object' &&\n 'AddressOwner' in change.owner &&\n change.owner.AddressOwner === this._address\n ) {\n const amt = Number(change.amount) / 10 ** toInfo.decimals;\n if (amt > 0) actualReceived += amt;\n }\n }\n }\n\n const expectedOutput = swapMeta.estimatedOut / 10 ** swapMeta.toDecimals;\n if (actualReceived === 0) actualReceived = expectedOutput;\n\n const priceImpact = expectedOutput > 0\n ? Math.abs(actualReceived - expectedOutput) / expectedOutput\n : 0;\n\n reportFee(this._address, 'swap', fee.amount, fee.rate, gasResult.digest);\n this.emitBalanceChange(fromAsset, swapAmount, 'swap', gasResult.digest);\n\n return {\n success: true,\n tx: gasResult.digest,\n fromAmount: swapAmount,\n fromAsset,\n toAmount: actualReceived,\n toAsset,\n priceImpact,\n fee: fee.amount,\n gasCost: gasResult.gasCostSui,\n gasMethod: gasResult.gasMethod,\n };\n }\n\n async swapQuote(params: { from: string; to: string; amount: number }): Promise<{\n expectedOutput: number;\n priceImpact: number;\n poolPrice: number;\n fee: { amount: number; rate: number };\n }> {\n const fromAsset = params.from.toUpperCase();\n const toAsset = params.to.toUpperCase();\n const best = await this.registry.bestSwapQuote(fromAsset, toAsset, params.amount);\n const fee = calculateFee('swap', params.amount);\n return { ...best.quote, fee: { amount: fee.amount, rate: fee.rate } };\n }\n\n // -- Info --\n\n async positions(): Promise<PositionsResult> {\n const allPositions = await this.registry.allPositions(this._address);\n const positions = allPositions.flatMap(p =>\n [\n ...p.positions.supplies.map(s => ({\n protocol: p.protocolId,\n asset: s.asset,\n type: 'save' as const,\n amount: s.amount,\n apy: s.apy,\n })),\n ...p.positions.borrows.map(b => ({\n protocol: p.protocolId,\n asset: b.asset,\n type: 'borrow' as const,\n amount: b.amount,\n apy: b.apy,\n })),\n ],\n );\n return { positions };\n }\n\n async rates(): Promise<RatesResult> {\n const allRatesResult = await this.registry.allRates('USDC');\n if (allRatesResult.length === 0) return { USDC: { saveApy: 0, borrowApy: 0 } };\n const best = allRatesResult.reduce((a, b) => (b.rates.saveApy > a.rates.saveApy ? b : a));\n return { USDC: { saveApy: best.rates.saveApy, borrowApy: best.rates.borrowApy } };\n }\n\n async allRates(asset = 'USDC') {\n return this.registry.allRates(asset);\n }\n\n async earnings(): Promise<EarningsResult> {\n const result = await yieldTracker.getEarnings(this.client, this.keypair);\n\n if (result.totalYieldEarned > 0) {\n this.emit('yield', {\n earned: result.dailyEarning,\n total: result.totalYieldEarned,\n apy: result.currentApy / 100,\n timestamp: Date.now(),\n });\n }\n\n return result;\n }\n\n async fundStatus(): Promise<FundStatusResult> {\n return yieldTracker.getFundStatus(this.client, this.keypair);\n }\n\n // -- Sentinel --\n\n async sentinelList(): Promise<SentinelAgent[]> {\n return sentinel.listSentinels();\n }\n\n async sentinelInfo(id: string): Promise<SentinelAgent> {\n return sentinel.getSentinelInfo(this.client, id);\n }\n\n async sentinelAttack(id: string, prompt: string, fee?: bigint): Promise<SentinelAttackResult> {\n return sentinel.attack(this.client, this.keypair, id, prompt, fee);\n }\n\n // -- Helpers --\n\n private async resolveLending(protocol: string | undefined, asset: string, capability: 'save' | 'withdraw' | 'borrow' | 'repay'): Promise<LendingAdapter> {\n if (protocol) {\n const adapter = this.registry.getLending(protocol);\n if (!adapter) throw new T2000Error('ASSET_NOT_SUPPORTED', `Lending adapter '${protocol}' not found`);\n return adapter;\n }\n\n if (capability === 'save') {\n const { adapter } = await this.registry.bestSaveRate(asset);\n return adapter;\n }\n\n if (capability === 'borrow' || capability === 'repay') {\n const adapters = this.registry.listLending().filter(\n a => a.supportedAssets.includes(asset) &&\n a.capabilities.includes(capability) &&\n (capability !== 'borrow' || a.supportsSameAssetBorrow),\n );\n if (adapters.length === 0) throw new T2000Error('ASSET_NOT_SUPPORTED', `No adapter supports ${capability} ${asset}`);\n return adapters[0];\n }\n\n const adapters = this.registry.listLending().filter(\n a => a.supportedAssets.includes(asset) && a.capabilities.includes(capability),\n );\n if (adapters.length === 0) throw new T2000Error('ASSET_NOT_SUPPORTED', `No adapter supports ${capability} ${asset}`);\n return adapters[0];\n }\n\n private emitBalanceChange(asset: string, amount: number, cause: string, tx?: string): void {\n this.emit('balanceChange', { asset, previous: 0, current: 0, cause, tx });\n }\n}\n\nasync function callSponsorApi(address: string, name?: string): Promise<void> {\n const res = await fetch(`${API_BASE_URL}/api/sponsor`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ address, name }),\n });\n\n if (res.status === 429) {\n const data = await res.json() as { challenge?: string };\n if (data.challenge) {\n const proof = solveHashcash(data.challenge);\n const retry = await fetch(`${API_BASE_URL}/api/sponsor`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ address, name, proof }),\n });\n if (!retry.ok) throw new T2000Error('SPONSOR_RATE_LIMITED', 'Sponsor rate limited');\n return;\n }\n }\n\n if (!res.ok) {\n throw new T2000Error('SPONSOR_FAILED', 'Sponsor API unavailable');\n }\n}\n","import type { SuiJsonRpcClient } from '@mysten/sui/jsonRpc';\nimport { Transaction } from '@mysten/sui/transactions';\nimport { T2000Error } from '../errors.js';\nimport { mapMoveAbortCode } from '../errors.js';\n\nexport interface SimulationResult {\n success: boolean;\n gasEstimateSui: number;\n error?: {\n moveAbortCode?: number;\n moveModule?: string;\n reason: string;\n rawError: string;\n };\n}\n\nexport async function simulateTransaction(\n client: SuiJsonRpcClient,\n tx: Transaction,\n sender: string,\n): Promise<SimulationResult> {\n tx.setSender(sender);\n\n try {\n const txBytes = await tx.build({ client });\n const dryRun = await client.dryRunTransactionBlock({\n transactionBlock: Buffer.from(txBytes).toString('base64'),\n });\n\n const status = dryRun.effects?.status;\n const gasUsed = dryRun.effects?.gasUsed;\n\n const gasEstimateSui = gasUsed\n ? (Number(gasUsed.computationCost) +\n Number(gasUsed.storageCost) -\n Number(gasUsed.storageRebate)) / 1e9\n : 0;\n\n if (status?.status === 'failure') {\n const rawError = status.error ?? 'Unknown simulation error';\n const parsed = parseMoveAbort(rawError);\n\n return {\n success: false,\n gasEstimateSui,\n error: {\n moveAbortCode: parsed.abortCode,\n moveModule: parsed.module,\n reason: parsed.reason,\n rawError,\n },\n };\n }\n\n return { success: true, gasEstimateSui };\n } catch (err) {\n const rawError = err instanceof Error ? err.message : String(err);\n return {\n success: false,\n gasEstimateSui: 0,\n error: {\n reason: 'Simulation failed: ' + rawError,\n rawError,\n },\n };\n }\n}\n\nexport function throwIfSimulationFailed(sim: SimulationResult): void {\n if (sim.success) return;\n\n throw new T2000Error(\n 'SIMULATION_FAILED',\n sim.error?.reason ?? 'Transaction simulation failed',\n {\n moveAbortCode: sim.error?.moveAbortCode,\n moveModule: sim.error?.moveModule,\n reason: sim.error?.reason,\n rawError: sim.error?.rawError,\n },\n );\n}\n\nfunction parseMoveAbort(errorStr: string): {\n abortCode?: number;\n module?: string;\n reason: string;\n} {\n // Pattern: MoveAbort(MoveLocation { module: ModuleId { ... name: \"module\" }, ... }, code)\n const abortMatch = errorStr.match(/MoveAbort\\([^,]*,\\s*(\\d+)\\)/);\n const moduleMatch = errorStr.match(/name:\\s*Identifier\\(\"([^\"]+)\"\\)/);\n\n if (abortMatch) {\n const code = parseInt(abortMatch[1], 10);\n const module = moduleMatch?.[1];\n const reason = mapMoveAbortCode(code);\n return { abortCode: code, module, reason };\n }\n\n // Pattern: MovePrimitiveRuntimeError\n if (errorStr.includes('MovePrimitiveRuntimeError')) {\n const module = moduleMatch?.[1];\n return {\n module,\n reason: `Move runtime error in ${module ?? 'unknown'} module`,\n };\n }\n\n return { reason: errorStr };\n}\n","export type {\n AdapterCapability,\n AdapterTxResult,\n LendingRates,\n AdapterPositions,\n HealthInfo,\n SwapQuote,\n LendingAdapter,\n SwapAdapter,\n ProtocolDescriptor,\n} from './types.js';\nexport { ProtocolRegistry } from './registry.js';\nexport { NaviAdapter, descriptor as naviDescriptor } from './navi.js';\nexport { CetusAdapter, descriptor as cetusDescriptor } from './cetus.js';\nexport { SuilendAdapter, descriptor as suilendDescriptor } from './suilend.js';\nexport { descriptor as sentinelDescriptor } from '../protocols/sentinel.js';\n\nimport { descriptor as naviDescriptor } from './navi.js';\nimport { descriptor as cetusDescriptor } from './cetus.js';\nimport { descriptor as suilendDescriptor } from './suilend.js';\nimport { descriptor as sentinelDescriptor } from '../protocols/sentinel.js';\nimport type { ProtocolDescriptor } from './types.js';\n\n/** All registered protocol descriptors — used by the indexer for event classification */\nexport const allDescriptors: ProtocolDescriptor[] = [\n naviDescriptor,\n suilendDescriptor,\n cetusDescriptor,\n sentinelDescriptor,\n];\n"]}