@luxexchange/api 1.0.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/.depcheckrc +17 -0
- package/.eslintrc.js +30 -0
- package/README.md +5 -0
- package/package.json +74 -0
- package/project.json +94 -0
- package/scripts/fixGraphQLApiTypes.mts +91 -0
- package/scripts/modifyTradingApiTypes.mts +232 -0
- package/src/client.ts +66 -0
- package/src/clients/auctions/createAuctionServiceClient.ts +44 -0
- package/src/clients/base/SharedQueryClient.ts +25 -0
- package/src/clients/base/auth.ts +43 -0
- package/src/clients/base/createFetchClient.ts +133 -0
- package/src/clients/base/errors.ts +32 -0
- package/src/clients/base/types.ts +26 -0
- package/src/clients/base/urls.test.ts +297 -0
- package/src/clients/base/urls.ts +85 -0
- package/src/clients/base/utils.test.ts +131 -0
- package/src/clients/base/utils.ts +54 -0
- package/src/clients/blockaid/createBlockaidApiClient.ts +185 -0
- package/src/clients/blockaid/types.ts +495 -0
- package/src/clients/content/types.ts +22 -0
- package/src/clients/conversionTracking/api-ConversionProxyService_connectquery.ts +20 -0
- package/src/clients/conversionTracking/api_connect.ts +24 -0
- package/src/clients/conversionTracking/api_pb.ts +184 -0
- package/src/clients/conversionTracking/index.ts +4 -0
- package/src/clients/data/createDataServiceApiClient.ts +101 -0
- package/src/clients/dataApi/createDataApiServiceClient.ts +29 -0
- package/src/clients/dataApi/getGetPortfolioQueryOptions.test.ts +122 -0
- package/src/clients/dataApi/getGetPortfolioQueryOptions.ts +76 -0
- package/src/clients/embeddedWallet/createEmbeddedWalletApiClient.ts +325 -0
- package/src/clients/for/createForApiClient.ts +187 -0
- package/src/clients/for/types.ts +39 -0
- package/src/clients/for/utils.ts +13 -0
- package/src/clients/graphql/__generated__/operations.ts +605 -0
- package/src/clients/graphql/__generated__/react-hooks.ts +4245 -0
- package/src/clients/graphql/__generated__/resolvers.ts +1469 -0
- package/src/clients/graphql/__generated__/schema-types.ts +2099 -0
- package/src/clients/graphql/codegen.config.ts +50 -0
- package/src/clients/graphql/fragments.ts +96 -0
- package/src/clients/graphql/generated.ts +5 -0
- package/src/clients/graphql/queries.graphql +1028 -0
- package/src/clients/graphql/queries.ts +19 -0
- package/src/clients/graphql/schema.graphql +1585 -0
- package/src/clients/graphql/types.ts +9 -0
- package/src/clients/graphql/utils.ts +21 -0
- package/src/clients/graphql/web/LuxPrices.graphql +18 -0
- package/src/clients/graphql/web/RecentTokenTransfers.graphql +93 -0
- package/src/clients/graphql/web/SimpleToken.graphql +12 -0
- package/src/clients/graphql/web/TokenSpotPrice.graphql +19 -0
- package/src/clients/graphql/web/activity.graphql +272 -0
- package/src/clients/graphql/web/allV3Ticks.graphql +11 -0
- package/src/clients/graphql/web/allV4Ticks.graphql +11 -0
- package/src/clients/graphql/web/feeTierDistribution.graphql +7 -0
- package/src/clients/graphql/web/landing.graphql +38 -0
- package/src/clients/graphql/web/latestSubgraphBlock.graphql +3 -0
- package/src/clients/graphql/web/nft/CollectionSearch.graphql +34 -0
- package/src/clients/graphql/web/nft/NftBalance.graphql +109 -0
- package/src/clients/graphql/web/pool.graphql +199 -0
- package/src/clients/graphql/web/poolTransactions.graphql +84 -0
- package/src/clients/graphql/web/portfolios.graphql +68 -0
- package/src/clients/graphql/web/token.graphql +97 -0
- package/src/clients/graphql/web/tokenCharts.graphql +85 -0
- package/src/clients/graphql/web/tokenTransactions.graphql +25 -0
- package/src/clients/graphql/web/topPools.graphql +78 -0
- package/src/clients/graphql/web/transactions.graphql +56 -0
- package/src/clients/jupiter/createJupiterApiClient.ts +42 -0
- package/src/clients/jupiter/types.ts +92 -0
- package/src/clients/jupiter/utils.ts +27 -0
- package/src/clients/liquidity/createAuctionMutationClient.ts +41 -0
- package/src/clients/liquidity/createLiquidityServiceClient.ts +56 -0
- package/src/clients/lux/createLuxApiClient.ts +100 -0
- package/src/clients/notifications/createNotificationsApiClient.ts +72 -0
- package/src/clients/notifications/types.ts +102 -0
- package/src/clients/trading/__generated__/core/ApiError.ts +25 -0
- package/src/clients/trading/__generated__/core/ApiRequestOptions.ts +17 -0
- package/src/clients/trading/__generated__/core/ApiResult.ts +11 -0
- package/src/clients/trading/__generated__/core/CancelablePromise.ts +131 -0
- package/src/clients/trading/__generated__/core/OpenAPI.ts +32 -0
- package/src/clients/trading/__generated__/core/request.ts +322 -0
- package/src/clients/trading/__generated__/index.ts +221 -0
- package/src/clients/trading/__generated__/models/Address.ts +5 -0
- package/src/clients/trading/__generated__/models/AggregatedOutput.ts +20 -0
- package/src/clients/trading/__generated__/models/ApprovalRequest.ts +25 -0
- package/src/clients/trading/__generated__/models/ApprovalResponse.ts +18 -0
- package/src/clients/trading/__generated__/models/AutoSlippage.ts +14 -0
- package/src/clients/trading/__generated__/models/BridgeQuote.ts +55 -0
- package/src/clients/trading/__generated__/models/ChainDelegationMap.ts +9 -0
- package/src/clients/trading/__generated__/models/ChainId.ts +29 -0
- package/src/clients/trading/__generated__/models/ChainedQuote.ts +63 -0
- package/src/clients/trading/__generated__/models/CheckApprovalLPRequest.ts +35 -0
- package/src/clients/trading/__generated__/models/CheckApprovalLPResponse.ts +29 -0
- package/src/clients/trading/__generated__/models/ClaimLPFeesRequest.ts +20 -0
- package/src/clients/trading/__generated__/models/ClaimLPFeesResponse.ts +13 -0
- package/src/clients/trading/__generated__/models/ClaimLPRewardsRequest.ts +19 -0
- package/src/clients/trading/__generated__/models/ClaimLPRewardsResponse.ts +13 -0
- package/src/clients/trading/__generated__/models/ClassicGasUseEstimateUSD.ts +8 -0
- package/src/clients/trading/__generated__/models/ClassicInput.ts +11 -0
- package/src/clients/trading/__generated__/models/ClassicOutput.ts +13 -0
- package/src/clients/trading/__generated__/models/ClassicQuote.ts +69 -0
- package/src/clients/trading/__generated__/models/ClientContext.ts +18 -0
- package/src/clients/trading/__generated__/models/CosignerData.ts +21 -0
- package/src/clients/trading/__generated__/models/CreateLPPositionRequest.ts +40 -0
- package/src/clients/trading/__generated__/models/CreateLPPositionResponse.ts +21 -0
- package/src/clients/trading/__generated__/models/CreatePlanRequest.ts +23 -0
- package/src/clients/trading/__generated__/models/CreateSendRequest.ts +22 -0
- package/src/clients/trading/__generated__/models/CreateSendResponse.ts +18 -0
- package/src/clients/trading/__generated__/models/CreateSwap5792Request.ts +17 -0
- package/src/clients/trading/__generated__/models/CreateSwap5792Response.ts +17 -0
- package/src/clients/trading/__generated__/models/CreateSwap7702Request.ts +21 -0
- package/src/clients/trading/__generated__/models/CreateSwap7702Response.ts +13 -0
- package/src/clients/trading/__generated__/models/CreateSwapRequest.ts +42 -0
- package/src/clients/trading/__generated__/models/CreateSwapResponse.ts +16 -0
- package/src/clients/trading/__generated__/models/Curve.ts +9 -0
- package/src/clients/trading/__generated__/models/DEXOrder.ts +35 -0
- package/src/clients/trading/__generated__/models/DecreaseLPPositionRequest.ts +33 -0
- package/src/clients/trading/__generated__/models/DecreaseLPPositionResponse.ts +19 -0
- package/src/clients/trading/__generated__/models/DelegationDetails.ts +19 -0
- package/src/clients/trading/__generated__/models/Distributor.ts +10 -0
- package/src/clients/trading/__generated__/models/DutchInput.ts +13 -0
- package/src/clients/trading/__generated__/models/DutchInputV3.ts +15 -0
- package/src/clients/trading/__generated__/models/DutchOrderInfo.ts +41 -0
- package/src/clients/trading/__generated__/models/DutchOrderInfoV2.ts +27 -0
- package/src/clients/trading/__generated__/models/DutchOrderInfoV3.ts +28 -0
- package/src/clients/trading/__generated__/models/DutchOutput.ts +15 -0
- package/src/clients/trading/__generated__/models/DutchOutputV3.ts +18 -0
- package/src/clients/trading/__generated__/models/DutchQuote.ts +27 -0
- package/src/clients/trading/__generated__/models/DutchQuoteV2.ts +28 -0
- package/src/clients/trading/__generated__/models/DutchQuoteV3.ts +30 -0
- package/src/clients/trading/__generated__/models/Encode7702ResponseBody.ts +11 -0
- package/src/clients/trading/__generated__/models/Err400.ts +9 -0
- package/src/clients/trading/__generated__/models/Err401.ts +9 -0
- package/src/clients/trading/__generated__/models/Err404.ts +17 -0
- package/src/clients/trading/__generated__/models/Err422.ts +9 -0
- package/src/clients/trading/__generated__/models/Err429.ts +9 -0
- package/src/clients/trading/__generated__/models/Err500.ts +9 -0
- package/src/clients/trading/__generated__/models/Err504.ts +9 -0
- package/src/clients/trading/__generated__/models/GasStrategy.ts +46 -0
- package/src/clients/trading/__generated__/models/GetOrdersResponse.ts +12 -0
- package/src/clients/trading/__generated__/models/GetSwappableTokensResponse.ts +29 -0
- package/src/clients/trading/__generated__/models/GetSwapsResponse.ts +18 -0
- package/src/clients/trading/__generated__/models/HooksOptions.ts +12 -0
- package/src/clients/trading/__generated__/models/IncreaseLPPositionRequest.ts +39 -0
- package/src/clients/trading/__generated__/models/IncreaseLPPositionResponse.ts +21 -0
- package/src/clients/trading/__generated__/models/IndependentToken.ts +8 -0
- package/src/clients/trading/__generated__/models/IndicativeQuoteRequest.ts +18 -0
- package/src/clients/trading/__generated__/models/IndicativeQuoteResponse.ts +14 -0
- package/src/clients/trading/__generated__/models/IndicativeQuoteToken.ts +13 -0
- package/src/clients/trading/__generated__/models/LimitOrderQuoteRequest.ts +22 -0
- package/src/clients/trading/__generated__/models/LimitOrderQuoteResponse.ts +19 -0
- package/src/clients/trading/__generated__/models/MigrateLPPositionRequest.ts +41 -0
- package/src/clients/trading/__generated__/models/MigrateLPPositionResponse.ts +13 -0
- package/src/clients/trading/__generated__/models/NullablePermit.ts +13 -0
- package/src/clients/trading/__generated__/models/OrderIds.ts +5 -0
- package/src/clients/trading/__generated__/models/OrderInput.ts +13 -0
- package/src/clients/trading/__generated__/models/OrderOutput.ts +16 -0
- package/src/clients/trading/__generated__/models/OrderRequest.ts +17 -0
- package/src/clients/trading/__generated__/models/OrderResponse.ts +13 -0
- package/src/clients/trading/__generated__/models/OrderStatus.ts +23 -0
- package/src/clients/trading/__generated__/models/OrderType.ts +11 -0
- package/src/clients/trading/__generated__/models/OrderTypeQuery.ts +12 -0
- package/src/clients/trading/__generated__/models/Permit.ts +13 -0
- package/src/clients/trading/__generated__/models/PermitAmount.ts +11 -0
- package/src/clients/trading/__generated__/models/PlanResponse.ts +75 -0
- package/src/clients/trading/__generated__/models/PlanStatus.ts +14 -0
- package/src/clients/trading/__generated__/models/PlanStep.ts +59 -0
- package/src/clients/trading/__generated__/models/PlanStepMethod.ts +12 -0
- package/src/clients/trading/__generated__/models/PlanStepPayloadType.ts +12 -0
- package/src/clients/trading/__generated__/models/PlanStepProof.ts +20 -0
- package/src/clients/trading/__generated__/models/PlanStepStatus.ts +14 -0
- package/src/clients/trading/__generated__/models/PlanStepType.ts +23 -0
- package/src/clients/trading/__generated__/models/Pool.ts +15 -0
- package/src/clients/trading/__generated__/models/PoolInfoRequest.ts +20 -0
- package/src/clients/trading/__generated__/models/PoolInfoResponse.ts +16 -0
- package/src/clients/trading/__generated__/models/PoolInformation.ts +44 -0
- package/src/clients/trading/__generated__/models/PoolParameters.ts +19 -0
- package/src/clients/trading/__generated__/models/PoolReferenceByProtocol.ts +12 -0
- package/src/clients/trading/__generated__/models/Position.ts +11 -0
- package/src/clients/trading/__generated__/models/PriorityInput.ts +12 -0
- package/src/clients/trading/__generated__/models/PriorityOrderInfo.ts +29 -0
- package/src/clients/trading/__generated__/models/PriorityOutput.ts +17 -0
- package/src/clients/trading/__generated__/models/PriorityQuote.ts +31 -0
- package/src/clients/trading/__generated__/models/ProtocolItems.ts +15 -0
- package/src/clients/trading/__generated__/models/Protocols.ts +9 -0
- package/src/clients/trading/__generated__/models/Quote.ts +14 -0
- package/src/clients/trading/__generated__/models/QuoteRequest.ts +41 -0
- package/src/clients/trading/__generated__/models/QuoteResponse.ts +19 -0
- package/src/clients/trading/__generated__/models/RequestId.ts +8 -0
- package/src/clients/trading/__generated__/models/Routing.ts +20 -0
- package/src/clients/trading/__generated__/models/RoutingPreference.ts +16 -0
- package/src/clients/trading/__generated__/models/SafetyLevel.ts +10 -0
- package/src/clients/trading/__generated__/models/ScopeData.ts +28 -0
- package/src/clients/trading/__generated__/models/SettledAmount.ts +14 -0
- package/src/clients/trading/__generated__/models/SortKey.ts +7 -0
- package/src/clients/trading/__generated__/models/SpreadOptimization.ts +11 -0
- package/src/clients/trading/__generated__/models/StepUpdate.ts +25 -0
- package/src/clients/trading/__generated__/models/SwapSafetyMode.ts +10 -0
- package/src/clients/trading/__generated__/models/SwapStatus.ts +11 -0
- package/src/clients/trading/__generated__/models/TokenInRoute.ts +20 -0
- package/src/clients/trading/__generated__/models/TokenProject.ts +13 -0
- package/src/clients/trading/__generated__/models/TokenProjectLogo.ts +8 -0
- package/src/clients/trading/__generated__/models/TradeType.ts +11 -0
- package/src/clients/trading/__generated__/models/TransactionFailureReason.ts +11 -0
- package/src/clients/trading/__generated__/models/TransactionHash.ts +8 -0
- package/src/clients/trading/__generated__/models/TransactionRequest.ts +29 -0
- package/src/clients/trading/__generated__/models/TransactionRequest5792.ts +25 -0
- package/src/clients/trading/__generated__/models/TruncatedPlanStep.ts +21 -0
- package/src/clients/trading/__generated__/models/UniversalRouterVersion.ts +8 -0
- package/src/clients/trading/__generated__/models/UpdatePlanRequest.ts +12 -0
- package/src/clients/trading/__generated__/models/Urgency.ts +12 -0
- package/src/clients/trading/__generated__/models/V2PoolInRoute.ts +19 -0
- package/src/clients/trading/__generated__/models/V2Reserve.ts +16 -0
- package/src/clients/trading/__generated__/models/V3PoolInRoute.ts +24 -0
- package/src/clients/trading/__generated__/models/V4PoolInRoute.ts +30 -0
- package/src/clients/trading/__generated__/models/WalletCheckDelegationRequestBody.ts +17 -0
- package/src/clients/trading/__generated__/models/WalletCheckDelegationResponseBody.ts +14 -0
- package/src/clients/trading/__generated__/models/WalletEncode7702RequestBody.ts +21 -0
- package/src/clients/trading/__generated__/models/WalletExecutionContext.ts +17 -0
- package/src/clients/trading/__generated__/models/WalletInfo.ts +22 -0
- package/src/clients/trading/__generated__/models/WalletProperties.ts +12 -0
- package/src/clients/trading/__generated__/models/WrapUnwrapQuote.ts +31 -0
- package/src/clients/trading/__generated__/models/additionalValidationContract.ts +9 -0
- package/src/clients/trading/__generated__/models/additionalValidationData.ts +9 -0
- package/src/clients/trading/__generated__/models/bps.ts +8 -0
- package/src/clients/trading/__generated__/models/bpsFee.ts +8 -0
- package/src/clients/trading/__generated__/models/bridgeTokenInChainIdParam.ts +6 -0
- package/src/clients/trading/__generated__/models/chainIdParam.ts +6 -0
- package/src/clients/trading/__generated__/models/claimerWalletAddress.ts +8 -0
- package/src/clients/trading/__generated__/models/contractAddress.ts +8 -0
- package/src/clients/trading/__generated__/models/cosignerAddress.ts +8 -0
- package/src/clients/trading/__generated__/models/cursorParam.ts +5 -0
- package/src/clients/trading/__generated__/models/deadline.ts +8 -0
- package/src/clients/trading/__generated__/models/encodedOrder.ts +8 -0
- package/src/clients/trading/__generated__/models/endAmount.ts +8 -0
- package/src/clients/trading/__generated__/models/erc20EthEnabledHeader.ts +8 -0
- package/src/clients/trading/__generated__/models/fillerParam.ts +9 -0
- package/src/clients/trading/__generated__/models/gasFee.ts +8 -0
- package/src/clients/trading/__generated__/models/gasFeeInCurrency.ts +8 -0
- package/src/clients/trading/__generated__/models/gasFeeUSD.ts +8 -0
- package/src/clients/trading/__generated__/models/gasLimit.ts +8 -0
- package/src/clients/trading/__generated__/models/gasPrice.ts +8 -0
- package/src/clients/trading/__generated__/models/generatePermitAsTransaction.ts +8 -0
- package/src/clients/trading/__generated__/models/includeGasInfo.ts +8 -0
- package/src/clients/trading/__generated__/models/inputToken.ts +8 -0
- package/src/clients/trading/__generated__/models/isSpam.ts +8 -0
- package/src/clients/trading/__generated__/models/limitParam.ts +5 -0
- package/src/clients/trading/__generated__/models/liquidity.ts +8 -0
- package/src/clients/trading/__generated__/models/lpPoolFee.ts +8 -0
- package/src/clients/trading/__generated__/models/lpTickCurrent.ts +8 -0
- package/src/clients/trading/__generated__/models/maxFeePerGas.ts +8 -0
- package/src/clients/trading/__generated__/models/maxPriorityFeePerGas.ts +8 -0
- package/src/clients/trading/__generated__/models/minAmount.ts +8 -0
- package/src/clients/trading/__generated__/models/nonce.ts +8 -0
- package/src/clients/trading/__generated__/models/orderId.ts +8 -0
- package/src/clients/trading/__generated__/models/orderIdParam.ts +6 -0
- package/src/clients/trading/__generated__/models/orderIdsParam.ts +9 -0
- package/src/clients/trading/__generated__/models/orderStatusParam.ts +9 -0
- package/src/clients/trading/__generated__/models/orderTypeParam.ts +9 -0
- package/src/clients/trading/__generated__/models/outputToken.ts +8 -0
- package/src/clients/trading/__generated__/models/poolFee.ts +8 -0
- package/src/clients/trading/__generated__/models/portionAmount.ts +8 -0
- package/src/clients/trading/__generated__/models/portionAmountReceiverAddress.ts +8 -0
- package/src/clients/trading/__generated__/models/portionBips.ts +8 -0
- package/src/clients/trading/__generated__/models/quoteId.ts +8 -0
- package/src/clients/trading/__generated__/models/receiverWalletAddress.ts +8 -0
- package/src/clients/trading/__generated__/models/senderWalletAddress.ts +8 -0
- package/src/clients/trading/__generated__/models/slippageTolerance.ts +14 -0
- package/src/clients/trading/__generated__/models/sortKeyParam.ts +9 -0
- package/src/clients/trading/__generated__/models/sortParam.ts +8 -0
- package/src/clients/trading/__generated__/models/sqrtRatioX96.ts +8 -0
- package/src/clients/trading/__generated__/models/startAmount.ts +8 -0
- package/src/clients/trading/__generated__/models/swapperParam.ts +9 -0
- package/src/clients/trading/__generated__/models/tickCurrent.ts +8 -0
- package/src/clients/trading/__generated__/models/tickSpacing.ts +8 -0
- package/src/clients/trading/__generated__/models/tokenAmount.ts +8 -0
- package/src/clients/trading/__generated__/models/tokenInParam.ts +6 -0
- package/src/clients/trading/__generated__/models/tokenSymbol.ts +8 -0
- package/src/clients/trading/__generated__/models/transactionHashesParam.ts +9 -0
- package/src/clients/trading/__generated__/models/universalRouterVersionHeader.ts +9 -0
- package/src/clients/trading/__generated__/services/ApprovalService.ts +39 -0
- package/src/clients/trading/__generated__/services/DefaultService.ts +46 -0
- package/src/clients/trading/__generated__/services/IndicativeQuoteService.ts +39 -0
- package/src/clients/trading/__generated__/services/LimitOrderQuoteService.ts +37 -0
- package/src/clients/trading/__generated__/services/LiquidityService.ts +239 -0
- package/src/clients/trading/__generated__/services/OrderService.ts +131 -0
- package/src/clients/trading/__generated__/services/PlanService.ts +76 -0
- package/src/clients/trading/__generated__/services/QuoteService.ts +58 -0
- package/src/clients/trading/__generated__/services/SendService.ts +37 -0
- package/src/clients/trading/__generated__/services/SwapService.ts +161 -0
- package/src/clients/trading/__generated__/services/SwappableTokensService.ts +42 -0
- package/src/clients/trading/__generated__/services/WalletCheckDelegationService.ts +37 -0
- package/src/clients/trading/__generated__/services/WalletEncode7702Service.ts +37 -0
- package/src/clients/trading/api.json +1 -0
- package/src/clients/trading/createTradingApiClient.ts +328 -0
- package/src/clients/trading/tradeTypes.ts +51 -0
- package/src/clients/trading/types.ts +72 -0
- package/src/clients/unitags/createUnitagsApiClient.test.ts +438 -0
- package/src/clients/unitags/createUnitagsApiClient.ts +214 -0
- package/src/clients/unitags/types.ts +122 -0
- package/src/components/ApiInit.test.tsx +364 -0
- package/src/components/ApiInit.tsx +71 -0
- package/src/connectRpc/base.ts +33 -0
- package/src/connectRpc/utils.ts +136 -0
- package/src/getEntryGatewayUrl.ts +46 -0
- package/src/getWebSocketUrl.ts +28 -0
- package/src/global.d.ts +2 -0
- package/src/hooks/index.ts +6 -0
- package/src/hooks/shared/types.ts +10 -0
- package/src/hooks/shared/useQueryWithImmediateGarbageCollection.ts +90 -0
- package/src/hooks/use-token-list.ts +52 -0
- package/src/hooks/use-token-price.ts +82 -0
- package/src/hooks/useIsSessionInitialized.ts +17 -0
- package/src/index.ts +318 -0
- package/src/provideDeviceIdService.ts +25 -0
- package/src/provideLuxIdentifierService.ts +25 -0
- package/src/provideSessionService.native.ts +46 -0
- package/src/provideSessionService.ts +13 -0
- package/src/provideSessionService.web.ts +87 -0
- package/src/provideSessionStorage.ts +21 -0
- package/src/session/createSessionTransport.test.ts +79 -0
- package/src/session/createSessionTransport.ts +107 -0
- package/src/session/createWithSessionRetry.ts +33 -0
- package/src/session/index.ts +12 -0
- package/src/storage/createExtensionStorageDriver.ts +29 -0
- package/src/storage/createNativeStorageDriver.ts +19 -0
- package/src/storage/createWebStorageDriver.ts +17 -0
- package/src/storage/getStorageDriver.native.ts +6 -0
- package/src/storage/getStorageDriver.ts +8 -0
- package/src/storage/getStorageDriver.web.ts +11 -0
- package/src/storage/types.ts +9 -0
- package/src/transport.ts +85 -0
- package/stubs/privy-service-connect.d.ts +3 -0
- package/stubs/privy-service-pb.d.ts +60 -0
- package/tsconfig.json +37 -0
- package/tsconfig.lint.json +8 -0
- package/tsconfig.spec.json +8 -0
- package/vitest.config.ts +14 -0
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
import type { FetchClient } from '@luxexchange/api/src/clients/base/types'
|
|
2
|
+
import { createFetcher } from '@luxexchange/api/src/clients/base/utils'
|
|
3
|
+
import { beforeEach, describe, expect, it, vi } from 'vitest'
|
|
4
|
+
|
|
5
|
+
describe('createFetcher', () => {
|
|
6
|
+
const mockClient: FetchClient = {
|
|
7
|
+
fetch: vi.fn().mockResolvedValue({ data: 'fetch' }),
|
|
8
|
+
get: vi.fn().mockResolvedValue({ data: 'get' }),
|
|
9
|
+
post: vi.fn().mockResolvedValue({ data: 'post' }),
|
|
10
|
+
put: vi.fn().mockResolvedValue({ data: 'put' }),
|
|
11
|
+
delete: vi.fn(),
|
|
12
|
+
patch: vi.fn(),
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
beforeEach(() => {
|
|
16
|
+
vi.clearAllMocks()
|
|
17
|
+
})
|
|
18
|
+
|
|
19
|
+
it('should create a fetcher for FETCH requests', async () => {
|
|
20
|
+
const fetcher = createFetcher<{ id: string }, { data: string }>({
|
|
21
|
+
client: mockClient,
|
|
22
|
+
method: 'fetch',
|
|
23
|
+
url: '/api/test',
|
|
24
|
+
})
|
|
25
|
+
const result = await fetcher({ id: '123' })
|
|
26
|
+
expect(result).toEqual({ data: 'fetch' })
|
|
27
|
+
})
|
|
28
|
+
|
|
29
|
+
it('should create a fetcher for GET requests', async () => {
|
|
30
|
+
const fetcher = createFetcher<{ id: string }, { data: string }>({
|
|
31
|
+
client: mockClient,
|
|
32
|
+
method: 'get',
|
|
33
|
+
url: '/api/test',
|
|
34
|
+
})
|
|
35
|
+
const result = await fetcher({ id: '123' })
|
|
36
|
+
expect(result).toEqual({ data: 'get' })
|
|
37
|
+
})
|
|
38
|
+
|
|
39
|
+
it('should create a fetcher for POST requests', async () => {
|
|
40
|
+
const fetcher = createFetcher<{ name: string }, { data: string }>({
|
|
41
|
+
client: mockClient,
|
|
42
|
+
method: 'post',
|
|
43
|
+
url: '/api/create',
|
|
44
|
+
})
|
|
45
|
+
const result = await fetcher({ name: 'test' })
|
|
46
|
+
expect(result).toEqual({ data: 'post' })
|
|
47
|
+
})
|
|
48
|
+
|
|
49
|
+
it('should apply transformRequest to modify url', async () => {
|
|
50
|
+
const fetcher = createFetcher<{ id: string }, { data: string }>({
|
|
51
|
+
client: mockClient,
|
|
52
|
+
method: 'get',
|
|
53
|
+
url: '/api/test',
|
|
54
|
+
transformRequest: async ({ url }) => ({ url: `${url}/modified` }),
|
|
55
|
+
})
|
|
56
|
+
await fetcher({ id: '123' })
|
|
57
|
+
expect(mockClient.get).toHaveBeenCalledWith(
|
|
58
|
+
'/api/test/modified',
|
|
59
|
+
expect.objectContaining({ params: { id: '123' } }),
|
|
60
|
+
)
|
|
61
|
+
})
|
|
62
|
+
|
|
63
|
+
it('should apply transformRequest to modify headers', async () => {
|
|
64
|
+
const fetcher = createFetcher<{ id: string }, { data: string }>({
|
|
65
|
+
client: mockClient,
|
|
66
|
+
method: 'get',
|
|
67
|
+
url: '/api/test',
|
|
68
|
+
transformRequest: async () => ({ headers: { Authorization: 'Bearer token' } }),
|
|
69
|
+
})
|
|
70
|
+
await fetcher({ id: '123' })
|
|
71
|
+
expect(mockClient.get).toHaveBeenCalledWith(
|
|
72
|
+
'/api/test',
|
|
73
|
+
expect.objectContaining({ headers: { Authorization: 'Bearer token' } }),
|
|
74
|
+
)
|
|
75
|
+
})
|
|
76
|
+
|
|
77
|
+
it('should apply transformRequest to modify params', async () => {
|
|
78
|
+
const fetcher = createFetcher<{ id: string }, { data: string }>({
|
|
79
|
+
client: mockClient,
|
|
80
|
+
method: 'get',
|
|
81
|
+
url: '/api/test',
|
|
82
|
+
transformRequest: async ({ params }) => ({ params: { ...params, extra: 'value' } }),
|
|
83
|
+
})
|
|
84
|
+
await fetcher({ id: '123' })
|
|
85
|
+
expect(mockClient.get).toHaveBeenCalledWith(
|
|
86
|
+
'/api/test',
|
|
87
|
+
expect.objectContaining({ params: { id: '123', extra: 'value' } }),
|
|
88
|
+
)
|
|
89
|
+
})
|
|
90
|
+
|
|
91
|
+
it('should apply transformRequest to modify url, headers, and params together', async () => {
|
|
92
|
+
const fetcher = createFetcher<{ id: string }, { data: string }>({
|
|
93
|
+
client: mockClient,
|
|
94
|
+
method: 'post',
|
|
95
|
+
url: '/api/test',
|
|
96
|
+
transformRequest: async ({ url, params }) => ({
|
|
97
|
+
url: `${url}/v2`,
|
|
98
|
+
headers: { 'X-Custom': 'header' },
|
|
99
|
+
params: { ...params, version: 2 },
|
|
100
|
+
}),
|
|
101
|
+
})
|
|
102
|
+
await fetcher({ id: '123' })
|
|
103
|
+
expect(mockClient.post).toHaveBeenCalledWith('/api/test/v2', {
|
|
104
|
+
headers: { 'X-Custom': 'header' },
|
|
105
|
+
body: JSON.stringify({ id: '123', version: 2 }),
|
|
106
|
+
on404: expect.any(Function),
|
|
107
|
+
})
|
|
108
|
+
})
|
|
109
|
+
|
|
110
|
+
it('should apply transformResponse when provided', async () => {
|
|
111
|
+
const fetcher = createFetcher<{ id: string }, { data: string }>({
|
|
112
|
+
client: mockClient,
|
|
113
|
+
method: 'get',
|
|
114
|
+
url: '/api/test',
|
|
115
|
+
transformResponse: (response) => ({ data: response.data.toUpperCase() }),
|
|
116
|
+
})
|
|
117
|
+
const result = await fetcher({ id: '123' })
|
|
118
|
+
expect(result).toEqual({ data: 'GET' })
|
|
119
|
+
})
|
|
120
|
+
|
|
121
|
+
it('should support async transformResponse', async () => {
|
|
122
|
+
const fetcher = createFetcher<{ id: string }, { data: string }>({
|
|
123
|
+
client: mockClient,
|
|
124
|
+
method: 'get',
|
|
125
|
+
url: '/api/test',
|
|
126
|
+
transformResponse: async (response) => ({ data: `transformed-${response.data}` }),
|
|
127
|
+
})
|
|
128
|
+
const result = await fetcher({ id: '123' })
|
|
129
|
+
expect(result).toEqual({ data: 'transformed-get' })
|
|
130
|
+
})
|
|
131
|
+
})
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { type CustomOptions, type FetchClient } from '@luxfi/api/src/clients/base/types'
|
|
2
|
+
|
|
3
|
+
type TransformRequestResult = {
|
|
4
|
+
url?: string
|
|
5
|
+
headers?: HeadersInit
|
|
6
|
+
params?: unknown
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
type TransformRequestInput<TRequest> = {
|
|
10
|
+
url: string
|
|
11
|
+
headers?: HeadersInit
|
|
12
|
+
params: TRequest
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export function createFetcher<TRequest, TResponse>(ctx: {
|
|
16
|
+
client: FetchClient
|
|
17
|
+
method: Extract<keyof FetchClient, 'get' | 'post' | 'put' | 'delete' | 'patch'>
|
|
18
|
+
url: string
|
|
19
|
+
transformRequest?: (request: TransformRequestInput<TRequest>) => Promise<TransformRequestResult>
|
|
20
|
+
transformResponse?: (response: TResponse) => TResponse | Promise<TResponse>
|
|
21
|
+
on404?: (params: TRequest) => void
|
|
22
|
+
}): (params: TRequest, customHeaders?: HeadersInit) => Promise<TResponse> {
|
|
23
|
+
const { client, url, method, transformRequest, transformResponse, on404 } = ctx
|
|
24
|
+
return async (params: TRequest, customHeaders?: HeadersInit): Promise<TResponse> => {
|
|
25
|
+
const transformedRequest = transformRequest ? await transformRequest({ url, headers: customHeaders, params }) : {}
|
|
26
|
+
const transformedUrl = transformedRequest.url ?? url
|
|
27
|
+
const transformedHeaders = transformedRequest.headers ?? {}
|
|
28
|
+
const transformedParams = transformedRequest.params ?? params
|
|
29
|
+
|
|
30
|
+
let response: TResponse
|
|
31
|
+
if (method === 'get') {
|
|
32
|
+
response = await client.get<TResponse>(transformedUrl, {
|
|
33
|
+
headers: { ...customHeaders, ...transformedHeaders },
|
|
34
|
+
params: transformedParams as CustomOptions['params'],
|
|
35
|
+
on404: () => on404?.(params),
|
|
36
|
+
})
|
|
37
|
+
} else {
|
|
38
|
+
response = await client[method]<TResponse>(transformedUrl, {
|
|
39
|
+
headers: { ...customHeaders, ...transformedHeaders },
|
|
40
|
+
body: JSON.stringify(transformedParams),
|
|
41
|
+
on404: () => on404?.(params),
|
|
42
|
+
})
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
return transformResponse ? transformResponse(response) : response
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
export const objectToQueryString = (obj: Record<string, string | number | boolean>): string => {
|
|
50
|
+
return Object.entries(obj)
|
|
51
|
+
.sort((a, b) => a[0].localeCompare(b[0]))
|
|
52
|
+
.map(([key, value]) => `${encodeURIComponent(key)}=${encodeURIComponent(value)}`)
|
|
53
|
+
.join('&')
|
|
54
|
+
}
|
|
@@ -0,0 +1,185 @@
|
|
|
1
|
+
import type { FetchClient } from '@luxfi/api/src/clients/base/types'
|
|
2
|
+
import {
|
|
3
|
+
type BlockaidScanJsonRpcRequest,
|
|
4
|
+
type BlockaidScanSiteRequest,
|
|
5
|
+
type BlockaidScanSiteResponse,
|
|
6
|
+
type BlockaidScanTransactionRequest,
|
|
7
|
+
type BlockaidScanTransactionResponse,
|
|
8
|
+
DappVerificationStatus,
|
|
9
|
+
getBlockaidScanSiteResponseSchema,
|
|
10
|
+
getBlockaidScanTransactionResponseSchema,
|
|
11
|
+
} from '@luxfi/api/src/clients/blockaid/types'
|
|
12
|
+
import { logger } from '@luxfi/utilities/src/logger/logger'
|
|
13
|
+
|
|
14
|
+
export interface BlockaidApiClient {
|
|
15
|
+
scanSite: (url: string) => Promise<DappVerificationStatus>
|
|
16
|
+
scanTransaction: (request: BlockaidScanTransactionRequest | null) => Promise<BlockaidScanTransactionResponse | null>
|
|
17
|
+
scanJsonRpc: (request: BlockaidScanJsonRpcRequest | null) => Promise<BlockaidScanTransactionResponse | null>
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export const BLOCKAID_API_PATHS = {
|
|
21
|
+
scanSite: '/v0/site/scan',
|
|
22
|
+
scanTransaction: '/v0/evm/transaction/scan',
|
|
23
|
+
scanJsonRpc: '/v0/evm/json-rpc/scan',
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
// Timeout for Blockaid API requests (5 seconds)
|
|
27
|
+
const BLOCKAID_TIMEOUT_MS = 5000
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* Maps a Blockaid API response to a DappVerificationStatus
|
|
31
|
+
* @param data The Blockaid API response
|
|
32
|
+
* @returns The corresponding DappVerificationStatus
|
|
33
|
+
*/
|
|
34
|
+
function mapBlockaidResponseToStatus(data: BlockaidScanSiteResponse): DappVerificationStatus {
|
|
35
|
+
if (data.status === 'miss') {
|
|
36
|
+
return DappVerificationStatus.Unverified
|
|
37
|
+
}
|
|
38
|
+
return data.is_malicious ? DappVerificationStatus.Threat : DappVerificationStatus.Verified
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export function createBlockaidApiClient(ctx: { fetchClient: FetchClient }): BlockaidApiClient {
|
|
42
|
+
async function scanSite(url: string): Promise<DappVerificationStatus> {
|
|
43
|
+
const requestBody: BlockaidScanSiteRequest = { url }
|
|
44
|
+
|
|
45
|
+
const abortController = new AbortController()
|
|
46
|
+
const timeoutId = setTimeout(() => abortController.abort(), BLOCKAID_TIMEOUT_MS)
|
|
47
|
+
|
|
48
|
+
try {
|
|
49
|
+
const result = await ctx.fetchClient.post(BLOCKAID_API_PATHS.scanSite, {
|
|
50
|
+
body: JSON.stringify(requestBody),
|
|
51
|
+
signal: abortController.signal,
|
|
52
|
+
})
|
|
53
|
+
|
|
54
|
+
const response = getBlockaidScanSiteResponseSchema().safeParse(result)
|
|
55
|
+
if (!response.success) {
|
|
56
|
+
logger.error(new Error('Blockaid API response schema validation failed'), {
|
|
57
|
+
tags: { file: 'createBlockaidApiClient', function: 'scanSite' },
|
|
58
|
+
extra: {
|
|
59
|
+
url,
|
|
60
|
+
validationError: response.error.message,
|
|
61
|
+
receivedData: result,
|
|
62
|
+
},
|
|
63
|
+
})
|
|
64
|
+
return DappVerificationStatus.Unverified
|
|
65
|
+
}
|
|
66
|
+
return mapBlockaidResponseToStatus(response.data)
|
|
67
|
+
} catch (error) {
|
|
68
|
+
// Log for observability but return safe default
|
|
69
|
+
logger.error(error, {
|
|
70
|
+
tags: {
|
|
71
|
+
file: 'createBlockaidApiClient',
|
|
72
|
+
function: 'scanSite',
|
|
73
|
+
},
|
|
74
|
+
extra: { url },
|
|
75
|
+
})
|
|
76
|
+
return DappVerificationStatus.Unverified
|
|
77
|
+
} finally {
|
|
78
|
+
clearTimeout(timeoutId)
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
async function scanTransaction(
|
|
83
|
+
request: BlockaidScanTransactionRequest | null,
|
|
84
|
+
): Promise<BlockaidScanTransactionResponse | null> {
|
|
85
|
+
if (!request) {
|
|
86
|
+
return null
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
const abortController = new AbortController()
|
|
90
|
+
const timeoutId = setTimeout(() => abortController.abort(), BLOCKAID_TIMEOUT_MS)
|
|
91
|
+
|
|
92
|
+
try {
|
|
93
|
+
const result = await ctx.fetchClient.post(BLOCKAID_API_PATHS.scanTransaction, {
|
|
94
|
+
body: JSON.stringify(request),
|
|
95
|
+
signal: abortController.signal,
|
|
96
|
+
})
|
|
97
|
+
|
|
98
|
+
const response = getBlockaidScanTransactionResponseSchema().safeParse(result)
|
|
99
|
+
if (!response.success) {
|
|
100
|
+
logger.error(new Error('Blockaid API response schema validation failed'), {
|
|
101
|
+
tags: { file: 'createBlockaidApiClient', function: 'scanTransaction' },
|
|
102
|
+
extra: {
|
|
103
|
+
chain: request.chain,
|
|
104
|
+
account: request.account_address,
|
|
105
|
+
domain: request.metadata.domain,
|
|
106
|
+
validationError: response.error.message,
|
|
107
|
+
receivedData: result,
|
|
108
|
+
},
|
|
109
|
+
})
|
|
110
|
+
return null
|
|
111
|
+
}
|
|
112
|
+
return response.data
|
|
113
|
+
} catch (error) {
|
|
114
|
+
// Log for observability but return null as safe default
|
|
115
|
+
logger.error(error, {
|
|
116
|
+
tags: {
|
|
117
|
+
file: 'createBlockaidApiClient',
|
|
118
|
+
function: 'scanTransaction',
|
|
119
|
+
},
|
|
120
|
+
extra: { chain: request.chain, account: request.account_address, domain: request.metadata.domain },
|
|
121
|
+
})
|
|
122
|
+
return null
|
|
123
|
+
} finally {
|
|
124
|
+
clearTimeout(timeoutId)
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
async function scanJsonRpc(
|
|
129
|
+
request: BlockaidScanJsonRpcRequest | null,
|
|
130
|
+
): Promise<BlockaidScanTransactionResponse | null> {
|
|
131
|
+
if (!request) {
|
|
132
|
+
return null
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
const abortController = new AbortController()
|
|
136
|
+
const timeoutId = setTimeout(() => abortController.abort(), BLOCKAID_TIMEOUT_MS)
|
|
137
|
+
|
|
138
|
+
try {
|
|
139
|
+
const result = await ctx.fetchClient.post(BLOCKAID_API_PATHS.scanJsonRpc, {
|
|
140
|
+
body: JSON.stringify(request),
|
|
141
|
+
signal: abortController.signal,
|
|
142
|
+
})
|
|
143
|
+
|
|
144
|
+
const response = getBlockaidScanTransactionResponseSchema().safeParse(result)
|
|
145
|
+
if (!response.success) {
|
|
146
|
+
logger.error(new Error('Blockaid API response schema validation failed'), {
|
|
147
|
+
tags: { file: 'createBlockaidApiClient', function: 'scanJsonRpc' },
|
|
148
|
+
extra: {
|
|
149
|
+
chain: request.chain,
|
|
150
|
+
account: request.account_address,
|
|
151
|
+
domain: request.metadata.domain,
|
|
152
|
+
method: request.data.method,
|
|
153
|
+
validationError: response.error.message,
|
|
154
|
+
receivedData: result,
|
|
155
|
+
},
|
|
156
|
+
})
|
|
157
|
+
return null
|
|
158
|
+
}
|
|
159
|
+
return response.data
|
|
160
|
+
} catch (error) {
|
|
161
|
+
// Log for observability but return null as safe default
|
|
162
|
+
logger.error(error, {
|
|
163
|
+
tags: {
|
|
164
|
+
file: 'createBlockaidApiClient',
|
|
165
|
+
function: 'scanJsonRpc',
|
|
166
|
+
},
|
|
167
|
+
extra: {
|
|
168
|
+
chain: request.chain,
|
|
169
|
+
account: request.account_address,
|
|
170
|
+
domain: request.metadata.domain,
|
|
171
|
+
method: request.data.method,
|
|
172
|
+
},
|
|
173
|
+
})
|
|
174
|
+
return null
|
|
175
|
+
} finally {
|
|
176
|
+
clearTimeout(timeoutId)
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
return {
|
|
181
|
+
scanSite,
|
|
182
|
+
scanTransaction,
|
|
183
|
+
scanJsonRpc,
|
|
184
|
+
}
|
|
185
|
+
}
|