@lifi/perps-sdk 0.1.1-alpha.8 → 0.2.0-alpha.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.
- package/README.md +38 -15
- package/dist/cjs/agent/AgentManager.d.ts +5 -5
- package/dist/cjs/agent/AgentManager.d.ts.map +1 -1
- package/dist/cjs/agent/AgentManager.js +16 -14
- package/dist/cjs/agent/AgentManager.js.map +1 -1
- package/dist/cjs/client/PerpsClient.d.ts +75 -21
- package/dist/cjs/client/PerpsClient.d.ts.map +1 -1
- package/dist/cjs/client/PerpsClient.js +642 -173
- package/dist/cjs/client/PerpsClient.js.map +1 -1
- package/dist/cjs/client/createPerpsClient.d.ts +15 -2
- package/dist/cjs/client/createPerpsClient.d.ts.map +1 -1
- package/dist/cjs/client/createPerpsClient.js +6 -3
- package/dist/cjs/client/createPerpsClient.js.map +1 -1
- package/dist/cjs/client/projectAccountConfigSettings.d.ts +3 -0
- package/dist/cjs/client/projectAccountConfigSettings.d.ts.map +1 -0
- package/dist/cjs/client/projectAccountConfigSettings.js +17 -0
- package/dist/cjs/client/projectAccountConfigSettings.js.map +1 -0
- package/dist/cjs/client/types.d.ts +49 -26
- package/dist/cjs/client/types.d.ts.map +1 -1
- package/dist/cjs/client/types.js +6 -0
- package/dist/cjs/client/types.js.map +1 -1
- package/dist/cjs/errors/PerpsError.d.ts +2 -3
- package/dist/cjs/errors/PerpsError.d.ts.map +1 -1
- package/dist/cjs/errors/PerpsError.js +3 -15
- package/dist/cjs/errors/PerpsError.js.map +1 -1
- package/dist/cjs/errors/constants.d.ts +0 -10
- package/dist/cjs/errors/constants.d.ts.map +1 -1
- package/dist/cjs/errors/constants.js +1 -12
- package/dist/cjs/errors/constants.js.map +1 -1
- package/dist/cjs/index.d.ts +37 -31
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +87 -42
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/providers/hyperliquid/accountConfig.d.ts +3 -0
- package/dist/cjs/providers/hyperliquid/accountConfig.d.ts.map +1 -0
- package/dist/cjs/providers/hyperliquid/accountConfig.js +41 -0
- package/dist/cjs/providers/hyperliquid/accountConfig.js.map +1 -0
- package/dist/cjs/providers/lighter/accountConfig.d.ts +3 -0
- package/dist/cjs/providers/lighter/accountConfig.d.ts.map +1 -0
- package/dist/cjs/providers/lighter/accountConfig.js +45 -0
- package/dist/cjs/providers/lighter/accountConfig.js.map +1 -0
- package/dist/cjs/realtime/PerpsWsClient.d.ts +7 -1
- package/dist/cjs/realtime/PerpsWsClient.d.ts.map +1 -1
- package/dist/cjs/realtime/PerpsWsClient.js +36 -23
- package/dist/cjs/realtime/PerpsWsClient.js.map +1 -1
- package/dist/cjs/realtime/hyperliquid/HyperliquidWsProvider.d.ts +9 -5
- package/dist/cjs/realtime/hyperliquid/HyperliquidWsProvider.d.ts.map +1 -1
- package/dist/cjs/realtime/hyperliquid/HyperliquidWsProvider.js +158 -52
- package/dist/cjs/realtime/hyperliquid/HyperliquidWsProvider.js.map +1 -1
- package/dist/cjs/realtime/hyperliquid/types.d.ts +11 -9
- package/dist/cjs/realtime/hyperliquid/types.d.ts.map +1 -1
- package/dist/cjs/realtime/lighter/LighterWsProvider.d.ts +48 -0
- package/dist/cjs/realtime/lighter/LighterWsProvider.d.ts.map +1 -0
- package/dist/cjs/realtime/lighter/LighterWsProvider.js +424 -0
- package/dist/cjs/realtime/lighter/LighterWsProvider.js.map +1 -0
- package/dist/cjs/realtime/lighter/types.d.ts +84 -0
- package/dist/cjs/realtime/lighter/types.d.ts.map +1 -0
- package/dist/cjs/{dex → realtime/lighter}/types.js.map +1 -1
- package/dist/cjs/services/createAction.d.ts +11 -0
- package/dist/cjs/services/createAction.d.ts.map +1 -0
- package/dist/cjs/services/{submitAuthorization.js → createAction.js} +7 -6
- package/dist/cjs/services/createAction.js.map +1 -0
- package/dist/cjs/services/executeAction.d.ts +11 -0
- package/dist/cjs/services/executeAction.d.ts.map +1 -0
- package/dist/cjs/services/{submitOrder.js → executeAction.js} +6 -5
- package/dist/cjs/services/executeAction.js.map +1 -0
- package/dist/cjs/services/getAccount.d.ts +1 -1
- package/dist/cjs/services/getAccount.d.ts.map +1 -1
- package/dist/cjs/services/getAccount.js +1 -1
- package/dist/cjs/services/getAccount.js.map +1 -1
- package/dist/cjs/services/getActivity.d.ts +13 -0
- package/dist/cjs/services/getActivity.d.ts.map +1 -0
- package/dist/cjs/services/getActivity.js +21 -0
- package/dist/cjs/services/getActivity.js.map +1 -0
- package/dist/cjs/services/getAsset.d.ts +8 -0
- package/dist/cjs/services/getAsset.d.ts.map +1 -0
- package/dist/cjs/services/{getMarkets.js → getAsset.js} +6 -4
- package/dist/cjs/services/getAsset.js.map +1 -0
- package/dist/cjs/services/getAssets.d.ts +7 -0
- package/dist/cjs/services/getAssets.d.ts.map +1 -0
- package/dist/cjs/services/{getMarket.js → getAssets.js} +5 -5
- package/dist/cjs/services/getAssets.js.map +1 -0
- package/dist/cjs/services/getFills.d.ts +12 -0
- package/dist/cjs/services/getFills.d.ts.map +1 -0
- package/dist/cjs/services/{getHistory.js → getFills.js} +7 -5
- package/dist/cjs/services/getFills.js.map +1 -0
- package/dist/cjs/services/getOhlcv.d.ts +1 -1
- package/dist/cjs/services/getOhlcv.d.ts.map +1 -1
- package/dist/cjs/services/getOhlcv.js +2 -2
- package/dist/cjs/services/getOhlcv.js.map +1 -1
- package/dist/cjs/services/getOrder.d.ts +1 -1
- package/dist/cjs/services/getOrder.d.ts.map +1 -1
- package/dist/cjs/services/getOrder.js +2 -2
- package/dist/cjs/services/getOrder.js.map +1 -1
- package/dist/cjs/services/getOrderbook.d.ts +1 -1
- package/dist/cjs/services/getOrderbook.d.ts.map +1 -1
- package/dist/cjs/services/getOrderbook.js +2 -2
- package/dist/cjs/services/getOrderbook.js.map +1 -1
- package/dist/cjs/services/getOrders.d.ts +11 -0
- package/dist/cjs/services/getOrders.d.ts.map +1 -0
- package/dist/cjs/services/getOrders.js +15 -0
- package/dist/cjs/services/getOrders.js.map +1 -0
- package/dist/cjs/services/getPositions.d.ts +11 -0
- package/dist/cjs/services/getPositions.d.ts.map +1 -0
- package/dist/cjs/services/getPositions.js +15 -0
- package/dist/cjs/services/getPositions.js.map +1 -0
- package/dist/cjs/services/getPrices.d.ts +1 -1
- package/dist/cjs/services/getPrices.d.ts.map +1 -1
- package/dist/cjs/services/getPrices.js +1 -1
- package/dist/cjs/services/getPrices.js.map +1 -1
- package/dist/cjs/services/getProviders.d.ts +4 -0
- package/dist/cjs/services/getProviders.d.ts.map +1 -0
- package/dist/cjs/services/{getDexes.js → getProviders.js} +4 -4
- package/dist/cjs/services/getProviders.js.map +1 -0
- package/dist/cjs/signers/lighter/LighterKeyStore.d.ts +20 -0
- package/dist/cjs/signers/lighter/LighterKeyStore.d.ts.map +1 -0
- package/dist/cjs/signers/lighter/LighterKeyStore.js +42 -0
- package/dist/cjs/signers/lighter/LighterKeyStore.js.map +1 -0
- package/dist/cjs/signers/lighter/LighterReadOnlyTokenManager.d.ts +66 -0
- package/dist/cjs/signers/lighter/LighterReadOnlyTokenManager.d.ts.map +1 -0
- package/dist/cjs/signers/lighter/LighterReadOnlyTokenManager.js +141 -0
- package/dist/cjs/signers/lighter/LighterReadOnlyTokenManager.js.map +1 -0
- package/dist/cjs/signers/lighter/LighterSigner.d.ts +41 -0
- package/dist/cjs/signers/lighter/LighterSigner.d.ts.map +1 -0
- package/dist/cjs/signers/lighter/LighterSigner.js +176 -0
- package/dist/cjs/signers/lighter/LighterSigner.js.map +1 -0
- package/dist/cjs/signers/lighter/index.d.ts +9 -0
- package/dist/cjs/signers/lighter/index.d.ts.map +1 -0
- package/dist/cjs/signers/lighter/index.js +20 -0
- package/dist/cjs/signers/lighter/index.js.map +1 -0
- package/dist/cjs/signers/lighter/wasmLoader.d.ts +42 -0
- package/dist/cjs/signers/lighter/wasmLoader.d.ts.map +1 -0
- package/dist/cjs/signers/lighter/wasmLoader.js +166 -0
- package/dist/cjs/signers/lighter/wasmLoader.js.map +1 -0
- package/dist/cjs/utils/accountSummary.d.ts +9 -0
- package/dist/cjs/utils/accountSummary.d.ts.map +1 -0
- package/dist/cjs/utils/accountSummary.js +83 -0
- package/dist/cjs/utils/accountSummary.js.map +1 -0
- package/dist/cjs/utils/assertNever.d.ts +2 -0
- package/dist/cjs/utils/assertNever.d.ts.map +1 -0
- package/dist/cjs/utils/assertNever.js +7 -0
- package/dist/cjs/utils/assertNever.js.map +1 -0
- package/dist/cjs/utils/calculations.d.ts +16 -0
- package/dist/cjs/utils/calculations.d.ts.map +1 -0
- package/dist/cjs/utils/calculations.js +71 -0
- package/dist/cjs/utils/calculations.js.map +1 -0
- package/dist/cjs/utils/hyperliquid/index.d.ts +3 -0
- package/dist/cjs/utils/hyperliquid/index.d.ts.map +1 -0
- package/dist/cjs/utils/hyperliquid/index.js +11 -0
- package/dist/cjs/utils/hyperliquid/index.js.map +1 -0
- package/dist/cjs/utils/hyperliquid/liquidation.d.ts +3 -0
- package/dist/cjs/utils/hyperliquid/liquidation.d.ts.map +1 -0
- package/dist/cjs/utils/hyperliquid/liquidation.js +24 -0
- package/dist/cjs/utils/hyperliquid/liquidation.js.map +1 -0
- package/dist/cjs/utils/hyperliquid/orderFormatting.d.ts +4 -0
- package/dist/cjs/utils/hyperliquid/orderFormatting.d.ts.map +1 -0
- package/dist/cjs/utils/hyperliquid/orderFormatting.js +33 -0
- package/dist/cjs/utils/hyperliquid/orderFormatting.js.map +1 -0
- package/dist/cjs/utils/orderClassification.d.ts +8 -0
- package/dist/cjs/utils/orderClassification.d.ts.map +1 -0
- package/dist/cjs/utils/orderClassification.js +39 -0
- package/dist/cjs/utils/orderClassification.js.map +1 -0
- package/dist/cjs/utils/orderMath.d.ts +6 -0
- package/dist/cjs/utils/orderMath.d.ts.map +1 -0
- package/dist/cjs/utils/orderMath.js +71 -0
- package/dist/cjs/utils/orderMath.js.map +1 -0
- package/dist/cjs/utils/parse.d.ts +2 -0
- package/dist/cjs/utils/parse.d.ts.map +1 -0
- package/dist/cjs/utils/parse.js +14 -0
- package/dist/cjs/utils/parse.js.map +1 -0
- package/dist/cjs/utils/positionMath.d.ts +26 -0
- package/dist/cjs/utils/positionMath.d.ts.map +1 -0
- package/dist/cjs/utils/positionMath.js +38 -0
- package/dist/cjs/utils/positionMath.js.map +1 -0
- package/dist/cjs/utils/request.d.ts.map +1 -1
- package/dist/cjs/utils/request.js +19 -4
- package/dist/cjs/utils/request.js.map +1 -1
- package/dist/cjs/utils/signTypedData.d.ts +2 -0
- package/dist/cjs/utils/signTypedData.d.ts.map +1 -1
- package/dist/cjs/utils/signTypedData.js +10 -3
- package/dist/cjs/utils/signTypedData.js.map +1 -1
- package/dist/cjs/utils/units.d.ts +3 -0
- package/dist/cjs/utils/units.d.ts.map +1 -0
- package/dist/cjs/utils/units.js +18 -0
- package/dist/cjs/utils/units.js.map +1 -0
- package/dist/cjs/utils/validation.d.ts +2 -0
- package/dist/cjs/utils/validation.d.ts.map +1 -0
- package/dist/cjs/utils/validation.js +16 -0
- package/dist/cjs/utils/validation.js.map +1 -0
- package/dist/cjs/version.d.ts +1 -1
- package/dist/cjs/version.js +1 -1
- package/dist/cjs/wasm/lighter-signer.wasm +0 -0
- package/dist/cjs/wasm/wasm_exec.js +575 -0
- package/dist/esm/agent/AgentManager.d.ts +9 -9
- package/dist/esm/agent/AgentManager.d.ts.map +1 -1
- package/dist/esm/agent/AgentManager.js +20 -18
- package/dist/esm/agent/AgentManager.js.map +1 -1
- package/dist/esm/agent/storage.d.ts +1 -1
- package/dist/esm/agent/storage.js +1 -1
- package/dist/esm/client/PerpsClient.d.ts +226 -144
- package/dist/esm/client/PerpsClient.d.ts.map +1 -1
- package/dist/esm/client/PerpsClient.js +869 -320
- package/dist/esm/client/PerpsClient.js.map +1 -1
- package/dist/esm/client/createPerpsClient.d.ts +30 -51
- package/dist/esm/client/createPerpsClient.d.ts.map +1 -1
- package/dist/esm/client/createPerpsClient.js +6 -21
- package/dist/esm/client/createPerpsClient.js.map +1 -1
- package/dist/esm/client/projectAccountConfigSettings.d.ts +18 -0
- package/dist/esm/client/projectAccountConfigSettings.d.ts.map +1 -0
- package/dist/esm/client/projectAccountConfigSettings.js +29 -0
- package/dist/esm/client/projectAccountConfigSettings.js.map +1 -0
- package/dist/esm/client/types.d.ts +115 -49
- package/dist/esm/client/types.d.ts.map +1 -1
- package/dist/esm/client/types.js +11 -1
- package/dist/esm/client/types.js.map +1 -1
- package/dist/esm/errors/PerpsError.d.ts +2 -3
- package/dist/esm/errors/PerpsError.d.ts.map +1 -1
- package/dist/esm/errors/PerpsError.js +3 -15
- package/dist/esm/errors/PerpsError.js.map +1 -1
- package/dist/esm/errors/constants.d.ts +0 -10
- package/dist/esm/errors/constants.d.ts.map +1 -1
- package/dist/esm/errors/constants.js +0 -11
- package/dist/esm/errors/constants.js.map +1 -1
- package/dist/esm/index.d.ts +37 -31
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +27 -22
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/providers/hyperliquid/accountConfig.d.ts +13 -0
- package/dist/esm/providers/hyperliquid/accountConfig.d.ts.map +1 -0
- package/dist/esm/providers/hyperliquid/accountConfig.js +69 -0
- package/dist/esm/providers/hyperliquid/accountConfig.js.map +1 -0
- package/dist/esm/providers/lighter/accountConfig.d.ts +13 -0
- package/dist/esm/providers/lighter/accountConfig.d.ts.map +1 -0
- package/dist/esm/providers/lighter/accountConfig.js +79 -0
- package/dist/esm/providers/lighter/accountConfig.js.map +1 -0
- package/dist/esm/realtime/PerpsWsClient.d.ts +13 -1
- package/dist/esm/realtime/PerpsWsClient.d.ts.map +1 -1
- package/dist/esm/realtime/PerpsWsClient.js +36 -23
- package/dist/esm/realtime/PerpsWsClient.js.map +1 -1
- package/dist/esm/realtime/hyperliquid/HyperliquidWsProvider.d.ts +11 -5
- package/dist/esm/realtime/hyperliquid/HyperliquidWsProvider.d.ts.map +1 -1
- package/dist/esm/realtime/hyperliquid/HyperliquidWsProvider.js +170 -53
- package/dist/esm/realtime/hyperliquid/HyperliquidWsProvider.js.map +1 -1
- package/dist/esm/realtime/hyperliquid/types.d.ts +11 -9
- package/dist/esm/realtime/hyperliquid/types.d.ts.map +1 -1
- package/dist/esm/realtime/lighter/LighterWsProvider.d.ts +68 -0
- package/dist/esm/realtime/lighter/LighterWsProvider.d.ts.map +1 -0
- package/dist/esm/realtime/lighter/LighterWsProvider.js +474 -0
- package/dist/esm/realtime/lighter/LighterWsProvider.js.map +1 -0
- package/dist/esm/realtime/lighter/types.d.ts +108 -0
- package/dist/esm/realtime/lighter/types.d.ts.map +1 -0
- package/dist/esm/realtime/lighter/types.js +14 -0
- package/dist/esm/realtime/lighter/types.js.map +1 -0
- package/dist/esm/services/createAction.d.ts +11 -0
- package/dist/esm/services/createAction.d.ts.map +1 -0
- package/dist/esm/services/createAction.js +14 -0
- package/dist/esm/services/createAction.js.map +1 -0
- package/dist/esm/services/executeAction.d.ts +11 -0
- package/dist/esm/services/executeAction.d.ts.map +1 -0
- package/dist/esm/services/executeAction.js +14 -0
- package/dist/esm/services/executeAction.js.map +1 -0
- package/dist/esm/services/getAccount.d.ts +7 -7
- package/dist/esm/services/getAccount.d.ts.map +1 -1
- package/dist/esm/services/getAccount.js +6 -6
- package/dist/esm/services/getAccount.js.map +1 -1
- package/dist/esm/services/getActivity.d.ts +49 -0
- package/dist/esm/services/getActivity.d.ts.map +1 -0
- package/dist/esm/services/getActivity.js +47 -0
- package/dist/esm/services/getActivity.js.map +1 -0
- package/dist/esm/services/getAsset.d.ts +20 -0
- package/dist/esm/services/getAsset.d.ts.map +1 -0
- package/dist/esm/services/getAsset.js +18 -0
- package/dist/esm/services/getAsset.js.map +1 -0
- package/dist/esm/services/getAssets.d.ts +18 -0
- package/dist/esm/services/getAssets.d.ts.map +1 -0
- package/dist/esm/services/getAssets.js +18 -0
- package/dist/esm/services/getAssets.js.map +1 -0
- package/dist/{types/services/getHistory.d.ts → esm/services/getFills.d.ts} +17 -13
- package/dist/esm/services/getFills.d.ts.map +1 -0
- package/dist/esm/services/{getHistory.js → getFills.js} +13 -11
- package/dist/esm/services/getFills.js.map +1 -0
- package/dist/esm/services/getOhlcv.d.ts +4 -4
- package/dist/esm/services/getOhlcv.d.ts.map +1 -1
- package/dist/esm/services/getOhlcv.js +4 -4
- package/dist/esm/services/getOhlcv.js.map +1 -1
- package/dist/esm/services/getOrder.d.ts +4 -4
- package/dist/esm/services/getOrder.d.ts.map +1 -1
- package/dist/esm/services/getOrder.js +4 -4
- package/dist/esm/services/getOrder.js.map +1 -1
- package/dist/esm/services/getOrderbook.d.ts +4 -4
- package/dist/esm/services/getOrderbook.d.ts.map +1 -1
- package/dist/esm/services/getOrderbook.js +4 -4
- package/dist/esm/services/getOrderbook.js.map +1 -1
- package/dist/esm/services/getOrders.d.ts +27 -0
- package/dist/esm/services/getOrders.d.ts.map +1 -0
- package/dist/esm/services/getOrders.js +23 -0
- package/dist/esm/services/getOrders.js.map +1 -0
- package/dist/esm/services/getPositions.d.ts +27 -0
- package/dist/esm/services/getPositions.d.ts.map +1 -0
- package/dist/esm/services/getPositions.js +23 -0
- package/dist/esm/services/getPositions.js.map +1 -0
- package/dist/esm/services/getPrices.d.ts +5 -5
- package/dist/esm/services/getPrices.d.ts.map +1 -1
- package/dist/esm/services/getPrices.js +4 -4
- package/dist/esm/services/getPrices.js.map +1 -1
- package/dist/esm/services/getProviders.d.ts +20 -0
- package/dist/esm/services/getProviders.d.ts.map +1 -0
- package/dist/esm/services/getProviders.js +21 -0
- package/dist/esm/services/getProviders.js.map +1 -0
- package/dist/esm/signers/lighter/LighterKeyStore.d.ts +29 -0
- package/dist/esm/signers/lighter/LighterKeyStore.d.ts.map +1 -0
- package/dist/esm/signers/lighter/LighterKeyStore.js +53 -0
- package/dist/esm/signers/lighter/LighterKeyStore.js.map +1 -0
- package/dist/esm/signers/lighter/LighterReadOnlyTokenManager.d.ts +174 -0
- package/dist/esm/signers/lighter/LighterReadOnlyTokenManager.d.ts.map +1 -0
- package/dist/esm/signers/lighter/LighterReadOnlyTokenManager.js +214 -0
- package/dist/esm/signers/lighter/LighterReadOnlyTokenManager.js.map +1 -0
- package/dist/esm/signers/lighter/LighterSigner.d.ts +88 -0
- package/dist/esm/signers/lighter/LighterSigner.d.ts.map +1 -0
- package/dist/esm/signers/lighter/LighterSigner.js +226 -0
- package/dist/esm/signers/lighter/LighterSigner.js.map +1 -0
- package/dist/esm/signers/lighter/index.d.ts +9 -0
- package/dist/esm/signers/lighter/index.d.ts.map +1 -0
- package/dist/esm/signers/lighter/index.js +5 -0
- package/dist/esm/signers/lighter/index.js.map +1 -0
- package/dist/esm/signers/lighter/wasmLoader.d.ts +71 -0
- package/dist/esm/signers/lighter/wasmLoader.d.ts.map +1 -0
- package/dist/esm/signers/lighter/wasmLoader.js +181 -0
- package/dist/esm/signers/lighter/wasmLoader.js.map +1 -0
- package/dist/esm/utils/accountSummary.d.ts +13 -0
- package/dist/esm/utils/accountSummary.d.ts.map +1 -0
- package/dist/esm/utils/accountSummary.js +97 -0
- package/dist/esm/utils/accountSummary.js.map +1 -0
- package/dist/esm/utils/assertNever.d.ts +19 -0
- package/dist/esm/utils/assertNever.d.ts.map +1 -0
- package/dist/esm/utils/assertNever.js +21 -0
- package/dist/esm/utils/assertNever.js.map +1 -0
- package/dist/esm/utils/calculations.d.ts +109 -0
- package/dist/esm/utils/calculations.d.ts.map +1 -0
- package/dist/esm/utils/calculations.js +154 -0
- package/dist/esm/utils/calculations.js.map +1 -0
- package/dist/esm/utils/hyperliquid/index.d.ts +3 -0
- package/dist/esm/utils/hyperliquid/index.d.ts.map +1 -0
- package/dist/esm/utils/hyperliquid/index.js +3 -0
- package/dist/esm/utils/hyperliquid/index.js.map +1 -0
- package/dist/esm/utils/hyperliquid/liquidation.d.ts +46 -0
- package/dist/esm/utils/hyperliquid/liquidation.d.ts.map +1 -0
- package/dist/esm/utils/hyperliquid/liquidation.js +63 -0
- package/dist/esm/utils/hyperliquid/liquidation.js.map +1 -0
- package/dist/esm/utils/hyperliquid/orderFormatting.d.ts +44 -0
- package/dist/esm/utils/hyperliquid/orderFormatting.d.ts.map +1 -0
- package/dist/esm/utils/hyperliquid/orderFormatting.js +79 -0
- package/dist/esm/utils/hyperliquid/orderFormatting.js.map +1 -0
- package/dist/esm/utils/orderClassification.d.ts +29 -0
- package/dist/esm/utils/orderClassification.d.ts.map +1 -0
- package/dist/esm/utils/orderClassification.js +53 -0
- package/dist/esm/utils/orderClassification.js.map +1 -0
- package/dist/esm/utils/orderMath.d.ts +40 -0
- package/dist/esm/utils/orderMath.d.ts.map +1 -0
- package/dist/esm/utils/orderMath.js +99 -0
- package/dist/esm/utils/orderMath.js.map +1 -0
- package/dist/esm/utils/parse.d.ts +18 -0
- package/dist/esm/utils/parse.d.ts.map +1 -0
- package/dist/esm/utils/parse.js +28 -0
- package/dist/esm/utils/parse.js.map +1 -0
- package/dist/esm/utils/positionMath.d.ts +78 -0
- package/dist/esm/utils/positionMath.d.ts.map +1 -0
- package/dist/esm/utils/positionMath.js +83 -0
- package/dist/esm/utils/positionMath.js.map +1 -0
- package/dist/esm/utils/request.d.ts +1 -2
- package/dist/esm/utils/request.d.ts.map +1 -1
- package/dist/esm/utils/request.js +23 -7
- package/dist/esm/utils/request.js.map +1 -1
- package/dist/esm/utils/signTypedData.d.ts +8 -10
- package/dist/esm/utils/signTypedData.d.ts.map +1 -1
- package/dist/esm/utils/signTypedData.js +15 -14
- package/dist/esm/utils/signTypedData.js.map +1 -1
- package/dist/esm/utils/units.d.ts +20 -0
- package/dist/esm/utils/units.d.ts.map +1 -0
- package/dist/esm/utils/units.js +31 -0
- package/dist/esm/utils/units.js.map +1 -0
- package/dist/esm/utils/validation.d.ts +15 -0
- package/dist/esm/utils/validation.d.ts.map +1 -0
- package/dist/esm/utils/validation.js +26 -0
- package/dist/esm/utils/validation.js.map +1 -0
- package/dist/esm/version.d.ts +1 -1
- package/dist/esm/version.js +1 -1
- package/dist/esm/wasm/lighter-signer.wasm +0 -0
- package/dist/esm/wasm/wasm_exec.js +575 -0
- package/dist/types/agent/AgentManager.d.ts +9 -9
- package/dist/types/agent/AgentManager.d.ts.map +1 -1
- package/dist/types/agent/storage.d.ts +1 -1
- package/dist/types/client/PerpsClient.d.ts +226 -144
- package/dist/types/client/PerpsClient.d.ts.map +1 -1
- package/dist/types/client/createPerpsClient.d.ts +30 -51
- package/dist/types/client/createPerpsClient.d.ts.map +1 -1
- package/dist/types/client/projectAccountConfigSettings.d.ts +18 -0
- package/dist/types/client/projectAccountConfigSettings.d.ts.map +1 -0
- package/dist/types/client/types.d.ts +115 -49
- package/dist/types/client/types.d.ts.map +1 -1
- package/dist/types/errors/PerpsError.d.ts +2 -3
- package/dist/types/errors/PerpsError.d.ts.map +1 -1
- package/dist/types/errors/constants.d.ts +0 -10
- package/dist/types/errors/constants.d.ts.map +1 -1
- package/dist/types/index.d.ts +37 -31
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/providers/hyperliquid/accountConfig.d.ts +13 -0
- package/dist/types/providers/hyperliquid/accountConfig.d.ts.map +1 -0
- package/dist/types/providers/lighter/accountConfig.d.ts +13 -0
- package/dist/types/providers/lighter/accountConfig.d.ts.map +1 -0
- package/dist/types/realtime/PerpsWsClient.d.ts +13 -1
- package/dist/types/realtime/PerpsWsClient.d.ts.map +1 -1
- package/dist/types/realtime/hyperliquid/HyperliquidWsProvider.d.ts +11 -5
- package/dist/types/realtime/hyperliquid/HyperliquidWsProvider.d.ts.map +1 -1
- package/dist/types/realtime/hyperliquid/types.d.ts +11 -9
- package/dist/types/realtime/hyperliquid/types.d.ts.map +1 -1
- package/dist/types/realtime/lighter/LighterWsProvider.d.ts +68 -0
- package/dist/types/realtime/lighter/LighterWsProvider.d.ts.map +1 -0
- package/dist/types/realtime/lighter/types.d.ts +108 -0
- package/dist/types/realtime/lighter/types.d.ts.map +1 -0
- package/dist/types/services/createAction.d.ts +11 -0
- package/dist/types/services/createAction.d.ts.map +1 -0
- package/dist/types/services/executeAction.d.ts +11 -0
- package/dist/types/services/executeAction.d.ts.map +1 -0
- package/dist/types/services/getAccount.d.ts +7 -7
- package/dist/types/services/getAccount.d.ts.map +1 -1
- package/dist/types/services/getActivity.d.ts +49 -0
- package/dist/types/services/getActivity.d.ts.map +1 -0
- package/dist/types/services/getAsset.d.ts +20 -0
- package/dist/types/services/getAsset.d.ts.map +1 -0
- package/dist/types/services/getAssets.d.ts +18 -0
- package/dist/types/services/getAssets.d.ts.map +1 -0
- package/dist/{esm/services/getHistory.d.ts → types/services/getFills.d.ts} +17 -13
- package/dist/types/services/getFills.d.ts.map +1 -0
- package/dist/types/services/getOhlcv.d.ts +4 -4
- package/dist/types/services/getOhlcv.d.ts.map +1 -1
- package/dist/types/services/getOrder.d.ts +4 -4
- package/dist/types/services/getOrder.d.ts.map +1 -1
- package/dist/types/services/getOrderbook.d.ts +4 -4
- package/dist/types/services/getOrderbook.d.ts.map +1 -1
- package/dist/types/services/getOrders.d.ts +27 -0
- package/dist/types/services/getOrders.d.ts.map +1 -0
- package/dist/types/services/getPositions.d.ts +27 -0
- package/dist/types/services/getPositions.d.ts.map +1 -0
- package/dist/types/services/getPrices.d.ts +5 -5
- package/dist/types/services/getPrices.d.ts.map +1 -1
- package/dist/types/services/getProviders.d.ts +20 -0
- package/dist/types/services/getProviders.d.ts.map +1 -0
- package/dist/types/signers/lighter/LighterKeyStore.d.ts +29 -0
- package/dist/types/signers/lighter/LighterKeyStore.d.ts.map +1 -0
- package/dist/types/signers/lighter/LighterReadOnlyTokenManager.d.ts +174 -0
- package/dist/types/signers/lighter/LighterReadOnlyTokenManager.d.ts.map +1 -0
- package/dist/types/signers/lighter/LighterSigner.d.ts +88 -0
- package/dist/types/signers/lighter/LighterSigner.d.ts.map +1 -0
- package/dist/types/signers/lighter/index.d.ts +9 -0
- package/dist/types/signers/lighter/index.d.ts.map +1 -0
- package/dist/types/signers/lighter/wasmLoader.d.ts +71 -0
- package/dist/types/signers/lighter/wasmLoader.d.ts.map +1 -0
- package/dist/types/utils/accountSummary.d.ts +13 -0
- package/dist/types/utils/accountSummary.d.ts.map +1 -0
- package/dist/types/utils/assertNever.d.ts +19 -0
- package/dist/types/utils/assertNever.d.ts.map +1 -0
- package/dist/types/utils/calculations.d.ts +109 -0
- package/dist/types/utils/calculations.d.ts.map +1 -0
- package/dist/types/utils/hyperliquid/index.d.ts +3 -0
- package/dist/types/utils/hyperliquid/index.d.ts.map +1 -0
- package/dist/types/utils/hyperliquid/liquidation.d.ts +46 -0
- package/dist/types/utils/hyperliquid/liquidation.d.ts.map +1 -0
- package/dist/types/utils/hyperliquid/orderFormatting.d.ts +44 -0
- package/dist/types/utils/hyperliquid/orderFormatting.d.ts.map +1 -0
- package/dist/types/utils/orderClassification.d.ts +29 -0
- package/dist/types/utils/orderClassification.d.ts.map +1 -0
- package/dist/types/utils/orderMath.d.ts +40 -0
- package/dist/types/utils/orderMath.d.ts.map +1 -0
- package/dist/types/utils/parse.d.ts +18 -0
- package/dist/types/utils/parse.d.ts.map +1 -0
- package/dist/types/utils/positionMath.d.ts +78 -0
- package/dist/types/utils/positionMath.d.ts.map +1 -0
- package/dist/types/utils/request.d.ts +1 -2
- package/dist/types/utils/request.d.ts.map +1 -1
- package/dist/types/utils/signTypedData.d.ts +8 -10
- package/dist/types/utils/signTypedData.d.ts.map +1 -1
- package/dist/types/utils/units.d.ts +20 -0
- package/dist/types/utils/units.d.ts.map +1 -0
- package/dist/types/utils/validation.d.ts +15 -0
- package/dist/types/utils/validation.d.ts.map +1 -0
- package/dist/types/version.d.ts +1 -1
- package/package.json +16 -8
- package/src/agent/AgentManager.ts +21 -19
- package/src/agent/storage.ts +1 -1
- package/src/client/PerpsClient.ts +1221 -396
- package/src/client/createPerpsClient.ts +39 -54
- package/src/client/projectAccountConfigSettings.ts +39 -0
- package/src/client/types.ts +130 -52
- package/src/errors/PerpsError.ts +3 -22
- package/src/errors/constants.ts +0 -11
- package/src/index.ts +115 -47
- package/src/providers/hyperliquid/accountConfig.ts +92 -0
- package/src/providers/lighter/accountConfig.ts +103 -0
- package/src/realtime/PerpsWsClient.ts +67 -32
- package/src/realtime/hyperliquid/HyperliquidWsProvider.ts +199 -64
- package/src/realtime/hyperliquid/types.ts +8 -10
- package/src/realtime/lighter/LighterWsProvider.ts +682 -0
- package/src/realtime/lighter/types.ts +121 -0
- package/src/services/createAction.ts +41 -0
- package/src/services/executeAction.ts +41 -0
- package/src/services/getAccount.ts +8 -8
- package/src/services/getActivity.ts +77 -0
- package/src/services/getAsset.ts +37 -0
- package/src/services/getAssets.ts +32 -0
- package/src/services/{getHistory.ts → getFills.ts} +23 -17
- package/src/services/getOhlcv.ts +14 -11
- package/src/services/getOrder.ts +11 -8
- package/src/services/getOrderbook.ts +11 -8
- package/src/services/getOrders.ts +45 -0
- package/src/services/getPositions.ts +45 -0
- package/src/services/getPrices.ts +6 -6
- package/src/services/{getDexes.ts → getProviders.ts} +10 -10
- package/src/signers/lighter/LighterKeyStore.ts +74 -0
- package/src/signers/lighter/LighterReadOnlyTokenManager.ts +358 -0
- package/src/signers/lighter/LighterSigner.ts +396 -0
- package/src/signers/lighter/index.ts +36 -0
- package/src/signers/lighter/wasmLoader.ts +291 -0
- package/src/utils/accountSummary.ts +130 -0
- package/src/utils/assertNever.ts +22 -0
- package/src/utils/calculations.ts +209 -0
- package/src/utils/hyperliquid/index.ts +9 -0
- package/src/utils/hyperliquid/liquidation.ts +71 -0
- package/src/utils/hyperliquid/orderFormatting.ts +96 -0
- package/src/utils/orderClassification.ts +64 -0
- package/src/utils/orderMath.ts +130 -0
- package/src/utils/parse.ts +28 -0
- package/src/utils/positionMath.ts +107 -0
- package/src/utils/request.ts +26 -7
- package/src/utils/signTypedData.ts +19 -15
- package/src/utils/units.ts +32 -0
- package/src/utils/validation.ts +35 -0
- package/src/version.ts +1 -1
- package/wasm/lighter-signer.wasm +0 -0
- package/wasm/wasm_exec.js +575 -0
- package/dist/cjs/dex/hyperliquid.d.ts +0 -3
- package/dist/cjs/dex/hyperliquid.d.ts.map +0 -1
- package/dist/cjs/dex/hyperliquid.js +0 -21
- package/dist/cjs/dex/hyperliquid.js.map +0 -1
- package/dist/cjs/dex/registry.d.ts +0 -3
- package/dist/cjs/dex/registry.d.ts.map +0 -1
- package/dist/cjs/dex/registry.js +0 -16
- package/dist/cjs/dex/registry.js.map +0 -1
- package/dist/cjs/dex/types.d.ts +0 -13
- package/dist/cjs/dex/types.d.ts.map +0 -1
- package/dist/cjs/errors/AgentError.d.ts +0 -10
- package/dist/cjs/errors/AgentError.d.ts.map +0 -1
- package/dist/cjs/errors/AgentError.js +0 -23
- package/dist/cjs/errors/AgentError.js.map +0 -1
- package/dist/cjs/errors/HTTPError.d.ts +0 -11
- package/dist/cjs/errors/HTTPError.d.ts.map +0 -1
- package/dist/cjs/errors/HTTPError.js +0 -62
- package/dist/cjs/errors/HTTPError.js.map +0 -1
- package/dist/cjs/errors/PerpsSDKError.d.ts +0 -9
- package/dist/cjs/errors/PerpsSDKError.d.ts.map +0 -1
- package/dist/cjs/errors/PerpsSDKError.js +0 -36
- package/dist/cjs/errors/PerpsSDKError.js.map +0 -1
- package/dist/cjs/errors/ServerError.d.ts +0 -10
- package/dist/cjs/errors/ServerError.d.ts.map +0 -1
- package/dist/cjs/errors/ServerError.js +0 -24
- package/dist/cjs/errors/ServerError.js.map +0 -1
- package/dist/cjs/errors/ValidationError.d.ts +0 -9
- package/dist/cjs/errors/ValidationError.d.ts.map +0 -1
- package/dist/cjs/errors/ValidationError.js +0 -23
- package/dist/cjs/errors/ValidationError.js.map +0 -1
- package/dist/cjs/errors/utils/rootCause.d.ts +0 -6
- package/dist/cjs/errors/utils/rootCause.d.ts.map +0 -1
- package/dist/cjs/errors/utils/rootCause.js +0 -41
- package/dist/cjs/errors/utils/rootCause.js.map +0 -1
- package/dist/cjs/services/cancelOrder.d.ts +0 -10
- package/dist/cjs/services/cancelOrder.d.ts.map +0 -1
- package/dist/cjs/services/cancelOrder.js +0 -16
- package/dist/cjs/services/cancelOrder.js.map +0 -1
- package/dist/cjs/services/createAuthorization.d.ts +0 -10
- package/dist/cjs/services/createAuthorization.d.ts.map +0 -1
- package/dist/cjs/services/createAuthorization.js +0 -16
- package/dist/cjs/services/createAuthorization.js.map +0 -1
- package/dist/cjs/services/createOrder.d.ts +0 -21
- package/dist/cjs/services/createOrder.d.ts.map +0 -1
- package/dist/cjs/services/createOrder.js +0 -27
- package/dist/cjs/services/createOrder.js.map +0 -1
- package/dist/cjs/services/createWithdrawal.d.ts +0 -9
- package/dist/cjs/services/createWithdrawal.d.ts.map +0 -1
- package/dist/cjs/services/createWithdrawal.js +0 -15
- package/dist/cjs/services/createWithdrawal.js.map +0 -1
- package/dist/cjs/services/getDexes.d.ts +0 -4
- package/dist/cjs/services/getDexes.d.ts.map +0 -1
- package/dist/cjs/services/getDexes.js.map +0 -1
- package/dist/cjs/services/getHistory.d.ts +0 -10
- package/dist/cjs/services/getHistory.d.ts.map +0 -1
- package/dist/cjs/services/getHistory.js.map +0 -1
- package/dist/cjs/services/getMarket.d.ts +0 -8
- package/dist/cjs/services/getMarket.d.ts.map +0 -1
- package/dist/cjs/services/getMarket.js.map +0 -1
- package/dist/cjs/services/getMarkets.d.ts +0 -7
- package/dist/cjs/services/getMarkets.d.ts.map +0 -1
- package/dist/cjs/services/getMarkets.js.map +0 -1
- package/dist/cjs/services/submitAuthorization.d.ts +0 -10
- package/dist/cjs/services/submitAuthorization.d.ts.map +0 -1
- package/dist/cjs/services/submitAuthorization.js.map +0 -1
- package/dist/cjs/services/submitOrder.d.ts +0 -10
- package/dist/cjs/services/submitOrder.d.ts.map +0 -1
- package/dist/cjs/services/submitOrder.js.map +0 -1
- package/dist/cjs/services/submitWithdrawal.d.ts +0 -9
- package/dist/cjs/services/submitWithdrawal.d.ts.map +0 -1
- package/dist/cjs/services/submitWithdrawal.js +0 -15
- package/dist/cjs/services/submitWithdrawal.js.map +0 -1
- package/dist/esm/dex/hyperliquid.d.ts +0 -3
- package/dist/esm/dex/hyperliquid.d.ts.map +0 -1
- package/dist/esm/dex/hyperliquid.js +0 -19
- package/dist/esm/dex/hyperliquid.js.map +0 -1
- package/dist/esm/dex/registry.d.ts +0 -3
- package/dist/esm/dex/registry.d.ts.map +0 -1
- package/dist/esm/dex/registry.js +0 -13
- package/dist/esm/dex/registry.js.map +0 -1
- package/dist/esm/dex/types.d.ts +0 -15
- package/dist/esm/dex/types.d.ts.map +0 -1
- package/dist/esm/dex/types.js +0 -2
- package/dist/esm/dex/types.js.map +0 -1
- package/dist/esm/errors/AgentError.d.ts +0 -25
- package/dist/esm/errors/AgentError.d.ts.map +0 -1
- package/dist/esm/errors/AgentError.js +0 -35
- package/dist/esm/errors/AgentError.js.map +0 -1
- package/dist/esm/errors/HTTPError.d.ts +0 -11
- package/dist/esm/errors/HTTPError.d.ts.map +0 -1
- package/dist/esm/errors/HTTPError.js +0 -61
- package/dist/esm/errors/HTTPError.js.map +0 -1
- package/dist/esm/errors/PerpsSDKError.d.ts +0 -40
- package/dist/esm/errors/PerpsSDKError.d.ts.map +0 -1
- package/dist/esm/errors/PerpsSDKError.js +0 -67
- package/dist/esm/errors/PerpsSDKError.js.map +0 -1
- package/dist/esm/errors/ServerError.d.ts +0 -23
- package/dist/esm/errors/ServerError.d.ts.map +0 -1
- package/dist/esm/errors/ServerError.js +0 -34
- package/dist/esm/errors/ServerError.js.map +0 -1
- package/dist/esm/errors/ValidationError.d.ts +0 -23
- package/dist/esm/errors/ValidationError.d.ts.map +0 -1
- package/dist/esm/errors/ValidationError.js +0 -34
- package/dist/esm/errors/ValidationError.js.map +0 -1
- package/dist/esm/errors/utils/rootCause.d.ts +0 -71
- package/dist/esm/errors/utils/rootCause.d.ts.map +0 -1
- package/dist/esm/errors/utils/rootCause.js +0 -99
- package/dist/esm/errors/utils/rootCause.js.map +0 -1
- package/dist/esm/services/cancelOrder.d.ts +0 -51
- package/dist/esm/services/cancelOrder.d.ts.map +0 -1
- package/dist/esm/services/cancelOrder.js +0 -50
- package/dist/esm/services/cancelOrder.js.map +0 -1
- package/dist/esm/services/createAuthorization.d.ts +0 -51
- package/dist/esm/services/createAuthorization.d.ts.map +0 -1
- package/dist/esm/services/createAuthorization.js +0 -50
- package/dist/esm/services/createAuthorization.js.map +0 -1
- package/dist/esm/services/createOrder.d.ts +0 -74
- package/dist/esm/services/createOrder.d.ts.map +0 -1
- package/dist/esm/services/createOrder.js +0 -62
- package/dist/esm/services/createOrder.js.map +0 -1
- package/dist/esm/services/createWithdrawal.d.ts +0 -49
- package/dist/esm/services/createWithdrawal.d.ts.map +0 -1
- package/dist/esm/services/createWithdrawal.js +0 -49
- package/dist/esm/services/createWithdrawal.js.map +0 -1
- package/dist/esm/services/getDexes.d.ts +0 -20
- package/dist/esm/services/getDexes.d.ts.map +0 -1
- package/dist/esm/services/getDexes.js +0 -21
- package/dist/esm/services/getDexes.js.map +0 -1
- package/dist/esm/services/getHistory.d.ts.map +0 -1
- package/dist/esm/services/getHistory.js.map +0 -1
- package/dist/esm/services/getMarket.d.ts +0 -27
- package/dist/esm/services/getMarket.d.ts.map +0 -1
- package/dist/esm/services/getMarket.js +0 -25
- package/dist/esm/services/getMarket.js.map +0 -1
- package/dist/esm/services/getMarkets.d.ts +0 -25
- package/dist/esm/services/getMarkets.d.ts.map +0 -1
- package/dist/esm/services/getMarkets.js +0 -23
- package/dist/esm/services/getMarkets.js.map +0 -1
- package/dist/esm/services/submitAuthorization.d.ts +0 -42
- package/dist/esm/services/submitAuthorization.d.ts.map +0 -1
- package/dist/esm/services/submitAuthorization.js +0 -41
- package/dist/esm/services/submitAuthorization.js.map +0 -1
- package/dist/esm/services/submitOrder.d.ts +0 -44
- package/dist/esm/services/submitOrder.d.ts.map +0 -1
- package/dist/esm/services/submitOrder.js +0 -43
- package/dist/esm/services/submitOrder.js.map +0 -1
- package/dist/esm/services/submitWithdrawal.d.ts +0 -40
- package/dist/esm/services/submitWithdrawal.d.ts.map +0 -1
- package/dist/esm/services/submitWithdrawal.js +0 -40
- package/dist/esm/services/submitWithdrawal.js.map +0 -1
- package/dist/types/dex/hyperliquid.d.ts +0 -3
- package/dist/types/dex/hyperliquid.d.ts.map +0 -1
- package/dist/types/dex/registry.d.ts +0 -3
- package/dist/types/dex/registry.d.ts.map +0 -1
- package/dist/types/dex/types.d.ts +0 -15
- package/dist/types/dex/types.d.ts.map +0 -1
- package/dist/types/errors/AgentError.d.ts +0 -25
- package/dist/types/errors/AgentError.d.ts.map +0 -1
- package/dist/types/errors/HTTPError.d.ts +0 -11
- package/dist/types/errors/HTTPError.d.ts.map +0 -1
- package/dist/types/errors/PerpsSDKError.d.ts +0 -40
- package/dist/types/errors/PerpsSDKError.d.ts.map +0 -1
- package/dist/types/errors/ServerError.d.ts +0 -23
- package/dist/types/errors/ServerError.d.ts.map +0 -1
- package/dist/types/errors/ValidationError.d.ts +0 -23
- package/dist/types/errors/ValidationError.d.ts.map +0 -1
- package/dist/types/errors/utils/rootCause.d.ts +0 -71
- package/dist/types/errors/utils/rootCause.d.ts.map +0 -1
- package/dist/types/services/cancelOrder.d.ts +0 -51
- package/dist/types/services/cancelOrder.d.ts.map +0 -1
- package/dist/types/services/createAuthorization.d.ts +0 -51
- package/dist/types/services/createAuthorization.d.ts.map +0 -1
- package/dist/types/services/createOrder.d.ts +0 -74
- package/dist/types/services/createOrder.d.ts.map +0 -1
- package/dist/types/services/createWithdrawal.d.ts +0 -49
- package/dist/types/services/createWithdrawal.d.ts.map +0 -1
- package/dist/types/services/getDexes.d.ts +0 -20
- package/dist/types/services/getDexes.d.ts.map +0 -1
- package/dist/types/services/getHistory.d.ts.map +0 -1
- package/dist/types/services/getMarket.d.ts +0 -27
- package/dist/types/services/getMarket.d.ts.map +0 -1
- package/dist/types/services/getMarkets.d.ts +0 -25
- package/dist/types/services/getMarkets.d.ts.map +0 -1
- package/dist/types/services/submitAuthorization.d.ts +0 -42
- package/dist/types/services/submitAuthorization.d.ts.map +0 -1
- package/dist/types/services/submitOrder.d.ts +0 -44
- package/dist/types/services/submitOrder.d.ts.map +0 -1
- package/dist/types/services/submitWithdrawal.d.ts +0 -40
- package/dist/types/services/submitWithdrawal.d.ts.map +0 -1
- package/src/dex/hyperliquid.ts +0 -20
- package/src/dex/registry.ts +0 -15
- package/src/dex/types.ts +0 -16
- package/src/errors/AgentError.ts +0 -43
- package/src/errors/HTTPError.ts +0 -72
- package/src/errors/PerpsSDKError.ts +0 -79
- package/src/errors/ServerError.ts +0 -41
- package/src/errors/ValidationError.ts +0 -38
- package/src/errors/utils/rootCause.ts +0 -112
- package/src/services/cancelOrder.ts +0 -75
- package/src/services/createAuthorization.ts +0 -79
- package/src/services/createOrder.ts +0 -116
- package/src/services/createWithdrawal.ts +0 -76
- package/src/services/getMarket.ts +0 -41
- package/src/services/getMarkets.ts +0 -37
- package/src/services/submitAuthorization.ts +0 -70
- package/src/services/submitOrder.ts +0 -72
- package/src/services/submitWithdrawal.ts +0 -67
- /package/dist/cjs/{dex → realtime/lighter}/types.js +0 -0
|
@@ -6,7 +6,7 @@ import { localStorageAdapter } from './storage.js';
|
|
|
6
6
|
const STORAGE_PREFIX = 'lifi-perps-agent';
|
|
7
7
|
/**
|
|
8
8
|
* Manages agent keypairs for USER_AGENT signing mode.
|
|
9
|
-
* Agent keys are stored per user address +
|
|
9
|
+
* Agent keys are stored per user address + provider combination.
|
|
10
10
|
*/
|
|
11
11
|
export class AgentManager {
|
|
12
12
|
storage;
|
|
@@ -17,16 +17,16 @@ export class AgentManager {
|
|
|
17
17
|
/**
|
|
18
18
|
* Get the storage key for an agent.
|
|
19
19
|
*/
|
|
20
|
-
storageKey(address,
|
|
21
|
-
return `${STORAGE_PREFIX}:${address.toLowerCase()}:${
|
|
20
|
+
storageKey(address, provider) {
|
|
21
|
+
return `${STORAGE_PREFIX}:${address.toLowerCase()}:${provider.toLowerCase()}`;
|
|
22
22
|
}
|
|
23
23
|
/**
|
|
24
|
-
* Get an existing agent for a user +
|
|
24
|
+
* Get an existing agent for a user + provider pair.
|
|
25
25
|
*
|
|
26
26
|
* @throws {PerpsError} If agent not found
|
|
27
27
|
*/
|
|
28
|
-
async getAgent(address,
|
|
29
|
-
const key = this.storageKey(address,
|
|
28
|
+
async getAgent(address, provider) {
|
|
29
|
+
const key = this.storageKey(address, provider);
|
|
30
30
|
// Check cache first
|
|
31
31
|
const cached = this.cache.get(key);
|
|
32
32
|
if (cached) {
|
|
@@ -39,14 +39,16 @@ export class AgentManager {
|
|
|
39
39
|
this.cache.set(key, agent);
|
|
40
40
|
return agent;
|
|
41
41
|
}
|
|
42
|
-
|
|
42
|
+
const error = new PerpsError(PerpsErrorCode.SDKError, PerpsErrorMessage.AgentNotFound);
|
|
43
|
+
error.tool = '@lifi/perps-sdk';
|
|
44
|
+
throw error;
|
|
43
45
|
}
|
|
44
46
|
/**
|
|
45
47
|
* Get an existing agent or create a new one.
|
|
46
48
|
*/
|
|
47
|
-
async getOrCreateAgent(address,
|
|
49
|
+
async getOrCreateAgent(address, provider) {
|
|
48
50
|
try {
|
|
49
|
-
return await this.getAgent(address,
|
|
51
|
+
return await this.getAgent(address, provider);
|
|
50
52
|
}
|
|
51
53
|
catch {
|
|
52
54
|
// Generate new agent
|
|
@@ -57,18 +59,18 @@ export class AgentManager {
|
|
|
57
59
|
privateKey,
|
|
58
60
|
};
|
|
59
61
|
// Store
|
|
60
|
-
const key = this.storageKey(address,
|
|
62
|
+
const key = this.storageKey(address, provider);
|
|
61
63
|
await this.storage.set(key, JSON.stringify(agent));
|
|
62
64
|
this.cache.set(key, agent);
|
|
63
65
|
return agent;
|
|
64
66
|
}
|
|
65
67
|
}
|
|
66
68
|
/**
|
|
67
|
-
* Check if an agent exists for a user +
|
|
69
|
+
* Check if an agent exists for a user + provider pair.
|
|
68
70
|
*/
|
|
69
|
-
async hasAgent(address,
|
|
71
|
+
async hasAgent(address, provider) {
|
|
70
72
|
try {
|
|
71
|
-
await this.getAgent(address,
|
|
73
|
+
await this.getAgent(address, provider);
|
|
72
74
|
return true;
|
|
73
75
|
}
|
|
74
76
|
catch {
|
|
@@ -76,11 +78,11 @@ export class AgentManager {
|
|
|
76
78
|
}
|
|
77
79
|
}
|
|
78
80
|
/**
|
|
79
|
-
* Remove an agent for a user +
|
|
81
|
+
* Remove an agent for a user + provider pair.
|
|
80
82
|
* Call this when the user revokes agent authorization.
|
|
81
83
|
*/
|
|
82
|
-
async removeAgent(address,
|
|
83
|
-
const key = this.storageKey(address,
|
|
84
|
+
async removeAgent(address, provider) {
|
|
85
|
+
const key = this.storageKey(address, provider);
|
|
84
86
|
this.cache.delete(key);
|
|
85
87
|
await this.storage.remove(key);
|
|
86
88
|
}
|
|
@@ -88,13 +90,13 @@ export class AgentManager {
|
|
|
88
90
|
* Import an existing agent keypair.
|
|
89
91
|
* Useful for restoring from backup or using a specific key.
|
|
90
92
|
*/
|
|
91
|
-
async importAgent(address,
|
|
93
|
+
async importAgent(address, provider, privateKey) {
|
|
92
94
|
const account = privateKeyToAccount(privateKey);
|
|
93
95
|
const agent = {
|
|
94
96
|
address: account.address,
|
|
95
97
|
privateKey,
|
|
96
98
|
};
|
|
97
|
-
const key = this.storageKey(address,
|
|
99
|
+
const key = this.storageKey(address, provider);
|
|
98
100
|
await this.storage.set(key, JSON.stringify(agent));
|
|
99
101
|
this.cache.set(key, agent);
|
|
100
102
|
return agent;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AgentManager.js","sourceRoot":"","sources":["../../../src/agent/AgentManager.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAA;AAClD,OAAO,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAA;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAA;AACpD,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAA;AAGlD,MAAM,cAAc,GAAG,kBAAkB,CAAA;AAEzC;;;GAGG;AACH,MAAM,OAAO,YAAY;IACf,OAAO,CAAgB;IACvB,KAAK,GAAuB,IAAI,GAAG,EAAE,CAAA;IAE7C,YAAY,OAAwB;QAClC,IAAI,CAAC,OAAO,GAAG,OAAO,IAAI,mBAAmB,CAAA;IAC/C,CAAC;IAED;;OAEG;IACK,UAAU,CAAC,OAAgB,EAAE,
|
|
1
|
+
{"version":3,"file":"AgentManager.js","sourceRoot":"","sources":["../../../src/agent/AgentManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,7 +2,7 @@ import type { StorageAdapter } from './types.js';
|
|
|
2
2
|
/**
|
|
3
3
|
* localStorage adapter for browser environments.
|
|
4
4
|
* Agent keys are stored as JSON strings with the key pattern:
|
|
5
|
-
* `lifi-perps-agent:{address}:{
|
|
5
|
+
* `lifi-perps-agent:{address}:{provider}`
|
|
6
6
|
*/
|
|
7
7
|
export declare const localStorageAdapter: StorageAdapter;
|
|
8
8
|
/**
|
|
@@ -1,198 +1,280 @@
|
|
|
1
|
-
import type {
|
|
2
|
-
import
|
|
3
|
-
import type
|
|
4
|
-
import type { SubmitWithdrawalParams } from '../services/submitWithdrawal.js';
|
|
1
|
+
import type { ActionParamsMap, ActionStep, Address, ApproveReadOnlyTokenParams, AssetIdentity, CreateActionResponse, ExecuteActionResponse, SignedActionStep } from '@lifi/perps-types';
|
|
2
|
+
import { ActionType } from '@lifi/perps-types';
|
|
3
|
+
import { type ApproveReadOnlyTokenResult } from '../signers/lighter/index.js';
|
|
5
4
|
import { type PerpsSDKClient } from './createPerpsClient.js';
|
|
6
|
-
import
|
|
7
|
-
/**
|
|
8
|
-
* Stateful client for managing signing modes and trading operations.
|
|
9
|
-
*
|
|
10
|
-
* The PerpsClient provides two signing modes:
|
|
11
|
-
* - `USER`: User wallet signs each action (wallet popup per action)
|
|
12
|
-
* - `USER_AGENT`: SDK-generated agent signs actions (no popups after setup)
|
|
13
|
-
*
|
|
14
|
-
* In `USER_AGENT` mode, the client:
|
|
15
|
-
* - Generates an agent keypair stored in localStorage (or custom storage)
|
|
16
|
-
* - Auto-injects agent address into authorization requests
|
|
17
|
-
* - Auto-signs trading actions with the agent key
|
|
18
|
-
*
|
|
19
|
-
* @remarks
|
|
20
|
-
* The example below uses Hyperliquid. Authorization keys and parameters are DEX-specific.
|
|
21
|
-
*
|
|
22
|
-
* @example
|
|
23
|
-
* ```ts
|
|
24
|
-
* const perps = new PerpsClient({ integrator: 'my-app' })
|
|
25
|
-
*
|
|
26
|
-
* // Set up agent signing for a user + DEX pair
|
|
27
|
-
* await perps.setSigningMode(userAddress, 'hyperliquid', 'USER_AGENT')
|
|
28
|
-
*
|
|
29
|
-
* // Check and execute required authorizations
|
|
30
|
-
* const required = await perps.getRequiredAuthorizations({
|
|
31
|
-
* dex: 'hyperliquid',
|
|
32
|
-
* address: userAddress,
|
|
33
|
-
* })
|
|
34
|
-
*
|
|
35
|
-
* // ... sign actions with user wallet ...
|
|
36
|
-
*
|
|
37
|
-
* // Place orders (agent signs automatically)
|
|
38
|
-
* const result = await perps.placeOrder({
|
|
39
|
-
* address: userAddress,
|
|
40
|
-
* dex: 'hyperliquid',
|
|
41
|
-
* symbol: 'BTC',
|
|
42
|
-
* side: 'BUY',
|
|
43
|
-
* type: 'MARKET',
|
|
44
|
-
* size: '0.1',
|
|
45
|
-
* price: '95000.00'
|
|
46
|
-
* })
|
|
47
|
-
* ```
|
|
48
|
-
*/
|
|
5
|
+
import { type CancelOrdersParams, type CheckPrerequisitesParams, type GetAccountResult, type GetSetupParams, type ModifyOrdersParams, type PerpsClientOptions, type PlaceOrderParams, type PlaceTriggerOrderParams, type SatisfySetupParams, type SatisfySetupResult, type SetupResult, SigningMode, type WithdrawParams } from './types.js';
|
|
49
6
|
export declare class PerpsClient {
|
|
50
7
|
private sdkClient;
|
|
8
|
+
private storage;
|
|
51
9
|
private signingModes;
|
|
10
|
+
private providerMetadataCache;
|
|
11
|
+
private _signer;
|
|
12
|
+
private readonly lighterConfig;
|
|
13
|
+
private readonly lighterReadOnlyTokenOptions;
|
|
14
|
+
private _lighterSigner;
|
|
15
|
+
private _lighterKeyStore;
|
|
16
|
+
private _lighterReadOnlyTokenManager;
|
|
52
17
|
constructor(options: PerpsClientOptions);
|
|
18
|
+
private getLighterSigner;
|
|
19
|
+
private getLighterKeyStore;
|
|
20
|
+
private getLighterReadOnlyTokenManager;
|
|
53
21
|
/**
|
|
54
|
-
*
|
|
22
|
+
* Set or update the wallet signer. Used whenever an action's descriptor
|
|
23
|
+
* names the user wallet in its `signers` list. Pass undefined to clear.
|
|
55
24
|
*/
|
|
25
|
+
setSigner(signer: PerpsSDKClient['signer']): void;
|
|
56
26
|
get client(): PerpsSDKClient;
|
|
57
|
-
/**
|
|
58
|
-
* Get the storage key for a user + DEX pair.
|
|
59
|
-
*/
|
|
60
27
|
private modeKey;
|
|
28
|
+
private signingModeStorageKey;
|
|
29
|
+
private getProviderMetadata;
|
|
61
30
|
/**
|
|
62
|
-
*
|
|
63
|
-
*
|
|
64
|
-
*
|
|
65
|
-
*
|
|
66
|
-
*
|
|
67
|
-
* @param dex - DEX identifier
|
|
68
|
-
* @param mode - Signing mode to set
|
|
31
|
+
* Action types that require explicit user input (a chosen mode or tier)
|
|
32
|
+
* and therefore cannot be bulk-staged through `buildPrerequisites` with
|
|
33
|
+
* empty params. Callers must dispatch these via `execute(...)` once a
|
|
34
|
+
* value is picked. The post-`APPROVE_AGENT` auto-upgrade path also
|
|
35
|
+
* dispatches `ACCOUNT_MODE` directly with `mode: 'unifiedAccount'`.
|
|
69
36
|
*/
|
|
70
|
-
|
|
37
|
+
private static readonly EXPLICIT_INPUT_PREREQUISITES;
|
|
38
|
+
private buildPrerequisiteInputs;
|
|
39
|
+
private resolveSignerForAction;
|
|
71
40
|
/**
|
|
72
|
-
*
|
|
73
|
-
*
|
|
41
|
+
* True if any descriptor for the provider lists `PerpsSigner.AGENT`.
|
|
42
|
+
* Providers like Lighter sign with their own keystore and never need an
|
|
43
|
+
* AgentManager-managed agent.
|
|
74
44
|
*/
|
|
75
|
-
|
|
45
|
+
private providerUsesAgent;
|
|
46
|
+
private autoSignAndExecute;
|
|
76
47
|
/**
|
|
77
|
-
*
|
|
78
|
-
*
|
|
79
|
-
*
|
|
48
|
+
* Sign a single prerequisite step using whichever signing path matches the
|
|
49
|
+
* step's shape — EIP-712 typed data, WASM blob (with the hybrid EIP-191 +
|
|
50
|
+
* WASM flow for REGISTER_API_KEY), or EVM transaction. Lets consumers
|
|
51
|
+
* collect signed prereqs without embedding per-method signing logic.
|
|
80
52
|
*/
|
|
81
|
-
|
|
53
|
+
signPrerequisite(provider: string, address: Address, step: ActionStep): Promise<SignedActionStep>;
|
|
82
54
|
/**
|
|
83
|
-
*
|
|
55
|
+
* Sign and broadcast a sequence of EVM transactions via the user's wallet
|
|
56
|
+
* client. Steps are submitted serially so a later step (e.g. deposit) can
|
|
57
|
+
* rely on an earlier step (e.g. approve) having mined. Each step's
|
|
58
|
+
* `txParams` carries chainId, target, function name, args, and a
|
|
59
|
+
* human-readable abi from the backend.
|
|
84
60
|
*/
|
|
85
|
-
|
|
61
|
+
private signEvmTxActions;
|
|
86
62
|
/**
|
|
87
|
-
*
|
|
88
|
-
*
|
|
63
|
+
* Sign a batch of WASM_BLOB action steps (Lighter). Ensures the user's
|
|
64
|
+
* Lighter API keypair is registered first — generating one and running the
|
|
65
|
+
* REGISTER_API_KEY hybrid flow via the L1 signer if not — then feeds each
|
|
66
|
+
* subsequent step through the WASM signer and returns signed blobs.
|
|
67
|
+
*
|
|
68
|
+
* `ACCOUNT_TYPE` (Lighter `/api/v1/changeAccountTier`) is dispatched as a
|
|
69
|
+
* WASM_BLOB envelope by the backend but is NOT a wasm-signed transaction —
|
|
70
|
+
* Lighter authenticates the endpoint with an auth token and enforces
|
|
71
|
+
* anti-replay server-side (24h cooldown, no open positions). The signer
|
|
72
|
+
* mints a Lighter auth token via the same WASM `CreateAuthToken` the read
|
|
73
|
+
* endpoints use and parks it in `signedTx.txInfo`; the backend's
|
|
74
|
+
* `executeChangeAccountTier` consumes that field as the `auth` form
|
|
75
|
+
* parameter. `txType`/`txHash` are unused for this action — they carry
|
|
76
|
+
* placeholder values to satisfy the `WasmBlobSignedActionStep` shape.
|
|
89
77
|
*/
|
|
90
|
-
|
|
78
|
+
private signWasmBlobActions;
|
|
79
|
+
private signStandardWasmAction;
|
|
91
80
|
/**
|
|
92
|
-
*
|
|
81
|
+
* REGISTER_API_KEY flow:
|
|
82
|
+
* 1. Look up the user's Lighter accountIndex from getAccount()
|
|
83
|
+
* 2. Generate a fresh Lighter API keypair via the WASM signer
|
|
84
|
+
* 3. Call SignChangePubKey to produce the WASM blob + EIP-191 message
|
|
85
|
+
* 4. Have the user's L1 Ethereum wallet sign the message
|
|
86
|
+
* 5. Inject the L1 signature into the ChangePubKey txInfo JSON
|
|
87
|
+
* 6. Persist the keypair and return the signed blob
|
|
93
88
|
*
|
|
94
|
-
*
|
|
95
|
-
*
|
|
96
|
-
*
|
|
97
|
-
* @param params - Authorization parameters
|
|
98
|
-
* @returns Authorization actions with typed data for signing
|
|
89
|
+
* Requires a USER wallet signer to be set via `setSigner` or passed at
|
|
90
|
+
* construction — the L1 signature is the user's consent to rotate keys.
|
|
99
91
|
*/
|
|
100
|
-
|
|
92
|
+
private signRegisterApiKey;
|
|
101
93
|
/**
|
|
102
|
-
*
|
|
94
|
+
* Sign an `ACCOUNT_TYPE` step (Lighter `changeAccountTier`).
|
|
103
95
|
*
|
|
104
|
-
*
|
|
105
|
-
*
|
|
96
|
+
* Lighter's `/api/v1/changeAccountTier` is an HTTP-only mutation —
|
|
97
|
+
* Lighter does NOT consume a wasm-signed transaction here; it
|
|
98
|
+
* authenticates the request with the same auth token its read endpoints
|
|
99
|
+
* use, and enforces anti-replay business rules server-side. The backend
|
|
100
|
+
* therefore declares the step as a `WasmBlobActionStep` with
|
|
101
|
+
* `wasmSignParams.kind = 'changeAccountTier'` and expects the SDK to
|
|
102
|
+
* mint an auth token in lieu of a transaction signature. That contract
|
|
103
|
+
* is documented in `lifi-perps-backend/src/providers/lighter/actions/
|
|
104
|
+
* lighter.actions.accountType.ts` and consumed by `executeChangeAccountTier`.
|
|
106
105
|
*
|
|
107
|
-
*
|
|
106
|
+
* The auth-token deadline mirrors {@link createLighterAuthToken}'s 1h
|
|
107
|
+
* default — Lighter caps tokens at 8h hard, and the backend's executor
|
|
108
|
+
* runs `verifyPendingAction` then a single `/changeAccountTier` POST,
|
|
109
|
+
* which completes well inside an hour.
|
|
108
110
|
*/
|
|
109
|
-
|
|
111
|
+
private signAccountTierChange;
|
|
110
112
|
/**
|
|
111
|
-
*
|
|
113
|
+
* Return a bearer token that authenticates Lighter's read endpoints
|
|
114
|
+
* (getOrders, getOrder, getActivity, getFills).
|
|
115
|
+
*
|
|
116
|
+
* Resolution order:
|
|
117
|
+
* 1. The long-lived read-only token persisted by `approveReadOnlyToken`,
|
|
118
|
+
* when one is stored for this `(address, accountIndex)` AND has not
|
|
119
|
+
* passed its recorded `expiry`. The SDK never returns an expired
|
|
120
|
+
* stored token.
|
|
121
|
+
* 2. A freshly minted 8h Lighter auth token, signed off the user's
|
|
122
|
+
* Lighter API key. Requires `REGISTER_API_KEY` to have completed.
|
|
123
|
+
* 3. `undefined` — caller falls back to public reads.
|
|
112
124
|
*
|
|
113
|
-
*
|
|
114
|
-
*
|
|
125
|
+
* `accountIndex` lets callers in pure read-only mode (no API key
|
|
126
|
+
* registered) target the RO token. When omitted, the SDK derives it from
|
|
127
|
+
* the user's registered API key.
|
|
115
128
|
*
|
|
116
|
-
*
|
|
117
|
-
*
|
|
129
|
+
* `deadlineSeconds` only affects the standard-token fallback (Lighter caps
|
|
130
|
+
* those tokens at 8h). Read-only tokens carry their own mint-time expiry
|
|
131
|
+
* recorded by {@link approveReadOnlyToken}.
|
|
118
132
|
*/
|
|
119
|
-
|
|
133
|
+
createLighterAuthToken(address: Address, deadlineSeconds?: number, accountIndex?: number): Promise<string | undefined>;
|
|
120
134
|
/**
|
|
121
|
-
*
|
|
135
|
+
* Mint a long-lived Lighter read-only token via Lighter's
|
|
136
|
+
* `tokens/create` endpoint and persist it through the configured
|
|
137
|
+
* `StorageAdapter`, keyed by `(L1 address, accountIndex)`.
|
|
138
|
+
*
|
|
139
|
+
* The user's connected wallet signs an EIP-191 message describing the
|
|
140
|
+
* mint request; the resulting `Authorization` header authenticates the
|
|
141
|
+
* Lighter HTTP call. The bearer string Lighter returns is persisted
|
|
142
|
+
* alongside its `expiry` and `scope`; subsequent calls to
|
|
143
|
+
* {@link createLighterAuthToken} prefer it over the 8h standard token.
|
|
122
144
|
*
|
|
123
|
-
*
|
|
124
|
-
*
|
|
145
|
+
* `expirySeconds` is the absolute unix-seconds expiry recorded on
|
|
146
|
+
* Lighter's row. Lighter enforces 1 day ≤ lifetime ≤ 10 years
|
|
147
|
+
* server-side; the SDK does NOT pre-validate and surfaces Lighter's 400
|
|
148
|
+
* verbatim. `scope` defaults to `'all'`; the `'single'` variant is wired
|
|
149
|
+
* through but only useful when the caller has a specific reason to scope
|
|
150
|
+
* the token to one account.
|
|
125
151
|
*
|
|
126
|
-
*
|
|
127
|
-
*
|
|
152
|
+
* Requires a USER wallet signer to be set via {@link setSigner} or
|
|
153
|
+
* passed at construction — the L1 signature is the user's consent.
|
|
128
154
|
*/
|
|
129
|
-
|
|
155
|
+
approveReadOnlyToken(address: Address, params: ApproveReadOnlyTokenParams): Promise<ApproveReadOnlyTokenResult>;
|
|
130
156
|
/**
|
|
131
|
-
*
|
|
132
|
-
*
|
|
133
|
-
*
|
|
134
|
-
*
|
|
135
|
-
*
|
|
136
|
-
* @returns Order submission results
|
|
137
|
-
* @throws {PerpsError} If not in USER_AGENT mode
|
|
157
|
+
* Whether the stored Lighter read-only token for `(address, accountIndex)`
|
|
158
|
+
* falls within `thresholdDays` of its `expiry`. Returns `false` when no
|
|
159
|
+
* token is stored, when the stored token has already expired, or when
|
|
160
|
+
* more than `thresholdDays` of life remain. Intended for widget renewal
|
|
161
|
+
* banners (default threshold: 30 days).
|
|
138
162
|
*/
|
|
139
|
-
|
|
163
|
+
isLighterReadOnlyTokenExpiringSoon(address: Address, accountIndex: number, thresholdDays?: number): Promise<boolean>;
|
|
164
|
+
buildAction<T extends ActionType>(action: T, params: {
|
|
165
|
+
provider: string;
|
|
166
|
+
address: Address;
|
|
167
|
+
params: ActionParamsMap[T];
|
|
168
|
+
}): Promise<CreateActionResponse>;
|
|
169
|
+
setSigningMode(address: Address, provider: string, mode: SigningMode): Promise<void>;
|
|
170
|
+
getSigningMode(address: Address, provider: string): SigningMode;
|
|
171
|
+
loadSigningMode(address: Address, provider: string): Promise<SigningMode>;
|
|
172
|
+
loadAgentMode(address: Address, provider: string): Promise<boolean>;
|
|
173
|
+
setAgentMode(address: Address, provider: string, useAgent: boolean): Promise<void>;
|
|
174
|
+
getAgentAddress(address: Address, provider: string): Promise<Address>;
|
|
175
|
+
hasAgent(address: Address, provider: string): Promise<boolean>;
|
|
176
|
+
removeAgent(address: Address, provider: string): Promise<void>;
|
|
140
177
|
/**
|
|
141
|
-
*
|
|
142
|
-
*
|
|
143
|
-
*
|
|
144
|
-
*
|
|
145
|
-
*
|
|
146
|
-
* @returns Cancel submission results
|
|
147
|
-
* @throws {PerpsError} If not in USER_AGENT mode
|
|
178
|
+
* Fetch the user's account state from the backend and attach the
|
|
179
|
+
* SDK-projected `settings` array — one `AccountConfigSetting` per
|
|
180
|
+
* descriptor on `Provider.setup` + `Provider.options`. Callers read
|
|
181
|
+
* `result.settings` directly without re-deriving values from the typed
|
|
182
|
+
* `AccountConfig`.
|
|
148
183
|
*/
|
|
149
|
-
|
|
184
|
+
getAccount(params: {
|
|
185
|
+
provider: string;
|
|
186
|
+
address: Address;
|
|
187
|
+
}): Promise<GetAccountResult>;
|
|
150
188
|
/**
|
|
151
|
-
*
|
|
152
|
-
*
|
|
153
|
-
*
|
|
154
|
-
*
|
|
155
|
-
*
|
|
156
|
-
* @param params - Signed order parameters
|
|
189
|
+
* Thin existence check for a provider account at `address`. Returns
|
|
190
|
+
* `true` when `getAccount` resolves, `false` when the backend reports
|
|
191
|
+
* `PerpsErrorCode.AccountNotFound`, and re-throws on any other error
|
|
192
|
+
* (transport failures, validation errors, server errors).
|
|
157
193
|
*/
|
|
158
|
-
|
|
194
|
+
accountExists(provider: string, address: Address): Promise<boolean>;
|
|
159
195
|
/**
|
|
160
|
-
*
|
|
161
|
-
*
|
|
162
|
-
* Withdrawals are user-signed only — agents cannot initiate withdrawals.
|
|
163
|
-
* No agent injection is performed regardless of signing mode.
|
|
196
|
+
* Return the unsatisfied entries on `Provider.setup` for this account,
|
|
197
|
+
* split by signer role. Trading is gated on `isReady === true`.
|
|
164
198
|
*
|
|
165
|
-
*
|
|
166
|
-
*
|
|
199
|
+
* `Provider.options` descriptors are NEVER returned here — options are
|
|
200
|
+
* post-setup tunables and never gate trading. Option state is surfaced
|
|
201
|
+
* separately via `getAccount().settings`.
|
|
167
202
|
*/
|
|
168
|
-
|
|
203
|
+
checkSetup(params: GetSetupParams): Promise<SetupResult>;
|
|
204
|
+
buildPrerequisites(params: CheckPrerequisitesParams): Promise<CreateActionResponse>;
|
|
169
205
|
/**
|
|
170
|
-
*
|
|
171
|
-
*
|
|
172
|
-
*
|
|
173
|
-
*
|
|
174
|
-
* @param params - Signed withdrawal parameters
|
|
175
|
-
* @returns Withdrawal result
|
|
206
|
+
* Default mode the SDK auto-applies after `APPROVE_AGENT` on a provider
|
|
207
|
+
* whose `options` array exposes a writable `ACCOUNT_MODE` (today
|
|
208
|
+
* Hyperliquid). Callers can override this through a subsequent
|
|
209
|
+
* `ACCOUNT_MODE` dispatch.
|
|
176
210
|
*/
|
|
177
|
-
|
|
211
|
+
private static readonly DEFAULT_ACCOUNT_MODE;
|
|
178
212
|
/**
|
|
179
|
-
*
|
|
213
|
+
* Prepare an `ACCOUNT_MODE` change by proactively reading the account's
|
|
214
|
+
* current `config.abstractionMode` and routing to the correct signer:
|
|
180
215
|
*
|
|
181
|
-
*
|
|
182
|
-
*
|
|
183
|
-
* and
|
|
216
|
+
* - `abstractionMode == null` (never set, e.g. a fresh HL account):
|
|
217
|
+
* the change MAY be performed by the agent signer. Build, sign with
|
|
218
|
+
* the agent key, and dispatch. Returns `{ results }`.
|
|
219
|
+
* - `abstractionMode === mode`: idempotent no-op. Returns an empty
|
|
220
|
+
* results envelope without contacting `/createAction` or `/executeAction`.
|
|
221
|
+
* - `abstractionMode` set to any other value: HL requires a user-wallet
|
|
222
|
+
* signature to change the abstraction once it has been set. Build the
|
|
223
|
+
* action unsigned and return it as `{ fallback }` so the caller can
|
|
224
|
+
* surface a wallet prompt via `fallbackUserPrerequisites`.
|
|
184
225
|
*
|
|
185
|
-
*
|
|
186
|
-
*
|
|
226
|
+
* Network errors from `/account` propagate — we never guess the signer.
|
|
227
|
+
* `account.config.provider !== 'hyperliquid'` also throws: this helper
|
|
228
|
+
* is HL-specific and the dispatcher should never reach it for another
|
|
229
|
+
* provider (gated by `hasWritableAccountMode`).
|
|
230
|
+
*/
|
|
231
|
+
private prepareAccountModeChange;
|
|
232
|
+
/**
|
|
233
|
+
* True when the provider exposes an `ACCOUNT_MODE` descriptor (in `setup`
|
|
234
|
+
* or `options`) whose `mode` Param has a writable enumeration of values.
|
|
235
|
+
* Providers that omit `ACCOUNT_MODE` or expose it as read-only / free-form
|
|
236
|
+
* input return false.
|
|
187
237
|
*/
|
|
188
|
-
|
|
238
|
+
private static hasWritableAccountMode;
|
|
189
239
|
/**
|
|
190
|
-
*
|
|
191
|
-
*
|
|
240
|
+
* Submit the signed setup steps returned by `checkSetup` (and seeded
|
|
241
|
+
* with user-wallet signatures by the caller). Internally splits into:
|
|
192
242
|
*
|
|
193
|
-
*
|
|
194
|
-
*
|
|
243
|
+
* 1. Submit user-signed setup actions.
|
|
244
|
+
* 2. After a successful `APPROVE_AGENT`, auto-upgrade `ACCOUNT_MODE`
|
|
245
|
+
* to the SDK's default when the provider exposes a writable
|
|
246
|
+
* `ACCOUNT_MODE` Param (Hyperliquid today). The SDK reads
|
|
247
|
+
* `account.config.abstractionMode` to choose the signer: `null` →
|
|
248
|
+
* agent dispatch; non-null → wallet fallback returned in
|
|
249
|
+
* `fallbackUserPrerequisites`.
|
|
250
|
+
* 3. Sign and submit any pre-staged agent-side setup actions the
|
|
251
|
+
* backend returned alongside the user-signed ones.
|
|
252
|
+
*/
|
|
253
|
+
satisfySetup(params: SatisfySetupParams): Promise<SatisfySetupResult>;
|
|
254
|
+
placeOrder(params: PlaceOrderParams): Promise<ExecuteActionResponse>;
|
|
255
|
+
placeTriggerOrder(params: PlaceTriggerOrderParams): Promise<ExecuteActionResponse>;
|
|
256
|
+
cancelOrders(params: CancelOrdersParams): Promise<ExecuteActionResponse>;
|
|
257
|
+
modifyOrders(params: ModifyOrdersParams): Promise<ExecuteActionResponse>;
|
|
258
|
+
updatePositionMargin(params: {
|
|
259
|
+
provider: string;
|
|
260
|
+
address: Address;
|
|
261
|
+
asset: AssetIdentity;
|
|
262
|
+
action: 'add' | 'remove';
|
|
263
|
+
amount: string;
|
|
264
|
+
}): Promise<ExecuteActionResponse>;
|
|
265
|
+
withdraw(params: WithdrawParams): Promise<ExecuteActionResponse>;
|
|
266
|
+
/**
|
|
267
|
+
* Execute any action through the SDK's signing pipeline. Signing is routed
|
|
268
|
+
* by the action's descriptor in provider metadata — the agent keypair, the
|
|
269
|
+
* configured WalletClient signer, the Lighter API key, or an EVM tx — as
|
|
270
|
+
* the descriptor's `signers` and `signingMethod` dictate.
|
|
195
271
|
*/
|
|
196
|
-
|
|
272
|
+
execute<T extends ActionType>(params: {
|
|
273
|
+
provider: string;
|
|
274
|
+
address: Address;
|
|
275
|
+
signerAddress?: Address;
|
|
276
|
+
action: T;
|
|
277
|
+
params: ActionParamsMap[T];
|
|
278
|
+
}): Promise<ExecuteActionResponse>;
|
|
197
279
|
}
|
|
198
280
|
//# sourceMappingURL=PerpsClient.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PerpsClient.d.ts","sourceRoot":"","sources":["../../../src/client/PerpsClient.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,OAAO,EACP,
|
|
1
|
+
{"version":3,"file":"PerpsClient.d.ts","sourceRoot":"","sources":["../../../src/client/PerpsClient.ts"],"names":[],"mappings":"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"}
|