@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.
Files changed (336) hide show
  1. package/.depcheckrc +17 -0
  2. package/.eslintrc.js +30 -0
  3. package/README.md +5 -0
  4. package/package.json +74 -0
  5. package/project.json +94 -0
  6. package/scripts/fixGraphQLApiTypes.mts +91 -0
  7. package/scripts/modifyTradingApiTypes.mts +232 -0
  8. package/src/client.ts +66 -0
  9. package/src/clients/auctions/createAuctionServiceClient.ts +44 -0
  10. package/src/clients/base/SharedQueryClient.ts +25 -0
  11. package/src/clients/base/auth.ts +43 -0
  12. package/src/clients/base/createFetchClient.ts +133 -0
  13. package/src/clients/base/errors.ts +32 -0
  14. package/src/clients/base/types.ts +26 -0
  15. package/src/clients/base/urls.test.ts +297 -0
  16. package/src/clients/base/urls.ts +85 -0
  17. package/src/clients/base/utils.test.ts +131 -0
  18. package/src/clients/base/utils.ts +54 -0
  19. package/src/clients/blockaid/createBlockaidApiClient.ts +185 -0
  20. package/src/clients/blockaid/types.ts +495 -0
  21. package/src/clients/content/types.ts +22 -0
  22. package/src/clients/conversionTracking/api-ConversionProxyService_connectquery.ts +20 -0
  23. package/src/clients/conversionTracking/api_connect.ts +24 -0
  24. package/src/clients/conversionTracking/api_pb.ts +184 -0
  25. package/src/clients/conversionTracking/index.ts +4 -0
  26. package/src/clients/data/createDataServiceApiClient.ts +101 -0
  27. package/src/clients/dataApi/createDataApiServiceClient.ts +29 -0
  28. package/src/clients/dataApi/getGetPortfolioQueryOptions.test.ts +122 -0
  29. package/src/clients/dataApi/getGetPortfolioQueryOptions.ts +76 -0
  30. package/src/clients/embeddedWallet/createEmbeddedWalletApiClient.ts +325 -0
  31. package/src/clients/for/createForApiClient.ts +187 -0
  32. package/src/clients/for/types.ts +39 -0
  33. package/src/clients/for/utils.ts +13 -0
  34. package/src/clients/graphql/__generated__/operations.ts +605 -0
  35. package/src/clients/graphql/__generated__/react-hooks.ts +4245 -0
  36. package/src/clients/graphql/__generated__/resolvers.ts +1469 -0
  37. package/src/clients/graphql/__generated__/schema-types.ts +2099 -0
  38. package/src/clients/graphql/codegen.config.ts +50 -0
  39. package/src/clients/graphql/fragments.ts +96 -0
  40. package/src/clients/graphql/generated.ts +5 -0
  41. package/src/clients/graphql/queries.graphql +1028 -0
  42. package/src/clients/graphql/queries.ts +19 -0
  43. package/src/clients/graphql/schema.graphql +1585 -0
  44. package/src/clients/graphql/types.ts +9 -0
  45. package/src/clients/graphql/utils.ts +21 -0
  46. package/src/clients/graphql/web/LuxPrices.graphql +18 -0
  47. package/src/clients/graphql/web/RecentTokenTransfers.graphql +93 -0
  48. package/src/clients/graphql/web/SimpleToken.graphql +12 -0
  49. package/src/clients/graphql/web/TokenSpotPrice.graphql +19 -0
  50. package/src/clients/graphql/web/activity.graphql +272 -0
  51. package/src/clients/graphql/web/allV3Ticks.graphql +11 -0
  52. package/src/clients/graphql/web/allV4Ticks.graphql +11 -0
  53. package/src/clients/graphql/web/feeTierDistribution.graphql +7 -0
  54. package/src/clients/graphql/web/landing.graphql +38 -0
  55. package/src/clients/graphql/web/latestSubgraphBlock.graphql +3 -0
  56. package/src/clients/graphql/web/nft/CollectionSearch.graphql +34 -0
  57. package/src/clients/graphql/web/nft/NftBalance.graphql +109 -0
  58. package/src/clients/graphql/web/pool.graphql +199 -0
  59. package/src/clients/graphql/web/poolTransactions.graphql +84 -0
  60. package/src/clients/graphql/web/portfolios.graphql +68 -0
  61. package/src/clients/graphql/web/token.graphql +97 -0
  62. package/src/clients/graphql/web/tokenCharts.graphql +85 -0
  63. package/src/clients/graphql/web/tokenTransactions.graphql +25 -0
  64. package/src/clients/graphql/web/topPools.graphql +78 -0
  65. package/src/clients/graphql/web/transactions.graphql +56 -0
  66. package/src/clients/jupiter/createJupiterApiClient.ts +42 -0
  67. package/src/clients/jupiter/types.ts +92 -0
  68. package/src/clients/jupiter/utils.ts +27 -0
  69. package/src/clients/liquidity/createAuctionMutationClient.ts +41 -0
  70. package/src/clients/liquidity/createLiquidityServiceClient.ts +56 -0
  71. package/src/clients/lux/createLuxApiClient.ts +100 -0
  72. package/src/clients/notifications/createNotificationsApiClient.ts +72 -0
  73. package/src/clients/notifications/types.ts +102 -0
  74. package/src/clients/trading/__generated__/core/ApiError.ts +25 -0
  75. package/src/clients/trading/__generated__/core/ApiRequestOptions.ts +17 -0
  76. package/src/clients/trading/__generated__/core/ApiResult.ts +11 -0
  77. package/src/clients/trading/__generated__/core/CancelablePromise.ts +131 -0
  78. package/src/clients/trading/__generated__/core/OpenAPI.ts +32 -0
  79. package/src/clients/trading/__generated__/core/request.ts +322 -0
  80. package/src/clients/trading/__generated__/index.ts +221 -0
  81. package/src/clients/trading/__generated__/models/Address.ts +5 -0
  82. package/src/clients/trading/__generated__/models/AggregatedOutput.ts +20 -0
  83. package/src/clients/trading/__generated__/models/ApprovalRequest.ts +25 -0
  84. package/src/clients/trading/__generated__/models/ApprovalResponse.ts +18 -0
  85. package/src/clients/trading/__generated__/models/AutoSlippage.ts +14 -0
  86. package/src/clients/trading/__generated__/models/BridgeQuote.ts +55 -0
  87. package/src/clients/trading/__generated__/models/ChainDelegationMap.ts +9 -0
  88. package/src/clients/trading/__generated__/models/ChainId.ts +29 -0
  89. package/src/clients/trading/__generated__/models/ChainedQuote.ts +63 -0
  90. package/src/clients/trading/__generated__/models/CheckApprovalLPRequest.ts +35 -0
  91. package/src/clients/trading/__generated__/models/CheckApprovalLPResponse.ts +29 -0
  92. package/src/clients/trading/__generated__/models/ClaimLPFeesRequest.ts +20 -0
  93. package/src/clients/trading/__generated__/models/ClaimLPFeesResponse.ts +13 -0
  94. package/src/clients/trading/__generated__/models/ClaimLPRewardsRequest.ts +19 -0
  95. package/src/clients/trading/__generated__/models/ClaimLPRewardsResponse.ts +13 -0
  96. package/src/clients/trading/__generated__/models/ClassicGasUseEstimateUSD.ts +8 -0
  97. package/src/clients/trading/__generated__/models/ClassicInput.ts +11 -0
  98. package/src/clients/trading/__generated__/models/ClassicOutput.ts +13 -0
  99. package/src/clients/trading/__generated__/models/ClassicQuote.ts +69 -0
  100. package/src/clients/trading/__generated__/models/ClientContext.ts +18 -0
  101. package/src/clients/trading/__generated__/models/CosignerData.ts +21 -0
  102. package/src/clients/trading/__generated__/models/CreateLPPositionRequest.ts +40 -0
  103. package/src/clients/trading/__generated__/models/CreateLPPositionResponse.ts +21 -0
  104. package/src/clients/trading/__generated__/models/CreatePlanRequest.ts +23 -0
  105. package/src/clients/trading/__generated__/models/CreateSendRequest.ts +22 -0
  106. package/src/clients/trading/__generated__/models/CreateSendResponse.ts +18 -0
  107. package/src/clients/trading/__generated__/models/CreateSwap5792Request.ts +17 -0
  108. package/src/clients/trading/__generated__/models/CreateSwap5792Response.ts +17 -0
  109. package/src/clients/trading/__generated__/models/CreateSwap7702Request.ts +21 -0
  110. package/src/clients/trading/__generated__/models/CreateSwap7702Response.ts +13 -0
  111. package/src/clients/trading/__generated__/models/CreateSwapRequest.ts +42 -0
  112. package/src/clients/trading/__generated__/models/CreateSwapResponse.ts +16 -0
  113. package/src/clients/trading/__generated__/models/Curve.ts +9 -0
  114. package/src/clients/trading/__generated__/models/DEXOrder.ts +35 -0
  115. package/src/clients/trading/__generated__/models/DecreaseLPPositionRequest.ts +33 -0
  116. package/src/clients/trading/__generated__/models/DecreaseLPPositionResponse.ts +19 -0
  117. package/src/clients/trading/__generated__/models/DelegationDetails.ts +19 -0
  118. package/src/clients/trading/__generated__/models/Distributor.ts +10 -0
  119. package/src/clients/trading/__generated__/models/DutchInput.ts +13 -0
  120. package/src/clients/trading/__generated__/models/DutchInputV3.ts +15 -0
  121. package/src/clients/trading/__generated__/models/DutchOrderInfo.ts +41 -0
  122. package/src/clients/trading/__generated__/models/DutchOrderInfoV2.ts +27 -0
  123. package/src/clients/trading/__generated__/models/DutchOrderInfoV3.ts +28 -0
  124. package/src/clients/trading/__generated__/models/DutchOutput.ts +15 -0
  125. package/src/clients/trading/__generated__/models/DutchOutputV3.ts +18 -0
  126. package/src/clients/trading/__generated__/models/DutchQuote.ts +27 -0
  127. package/src/clients/trading/__generated__/models/DutchQuoteV2.ts +28 -0
  128. package/src/clients/trading/__generated__/models/DutchQuoteV3.ts +30 -0
  129. package/src/clients/trading/__generated__/models/Encode7702ResponseBody.ts +11 -0
  130. package/src/clients/trading/__generated__/models/Err400.ts +9 -0
  131. package/src/clients/trading/__generated__/models/Err401.ts +9 -0
  132. package/src/clients/trading/__generated__/models/Err404.ts +17 -0
  133. package/src/clients/trading/__generated__/models/Err422.ts +9 -0
  134. package/src/clients/trading/__generated__/models/Err429.ts +9 -0
  135. package/src/clients/trading/__generated__/models/Err500.ts +9 -0
  136. package/src/clients/trading/__generated__/models/Err504.ts +9 -0
  137. package/src/clients/trading/__generated__/models/GasStrategy.ts +46 -0
  138. package/src/clients/trading/__generated__/models/GetOrdersResponse.ts +12 -0
  139. package/src/clients/trading/__generated__/models/GetSwappableTokensResponse.ts +29 -0
  140. package/src/clients/trading/__generated__/models/GetSwapsResponse.ts +18 -0
  141. package/src/clients/trading/__generated__/models/HooksOptions.ts +12 -0
  142. package/src/clients/trading/__generated__/models/IncreaseLPPositionRequest.ts +39 -0
  143. package/src/clients/trading/__generated__/models/IncreaseLPPositionResponse.ts +21 -0
  144. package/src/clients/trading/__generated__/models/IndependentToken.ts +8 -0
  145. package/src/clients/trading/__generated__/models/IndicativeQuoteRequest.ts +18 -0
  146. package/src/clients/trading/__generated__/models/IndicativeQuoteResponse.ts +14 -0
  147. package/src/clients/trading/__generated__/models/IndicativeQuoteToken.ts +13 -0
  148. package/src/clients/trading/__generated__/models/LimitOrderQuoteRequest.ts +22 -0
  149. package/src/clients/trading/__generated__/models/LimitOrderQuoteResponse.ts +19 -0
  150. package/src/clients/trading/__generated__/models/MigrateLPPositionRequest.ts +41 -0
  151. package/src/clients/trading/__generated__/models/MigrateLPPositionResponse.ts +13 -0
  152. package/src/clients/trading/__generated__/models/NullablePermit.ts +13 -0
  153. package/src/clients/trading/__generated__/models/OrderIds.ts +5 -0
  154. package/src/clients/trading/__generated__/models/OrderInput.ts +13 -0
  155. package/src/clients/trading/__generated__/models/OrderOutput.ts +16 -0
  156. package/src/clients/trading/__generated__/models/OrderRequest.ts +17 -0
  157. package/src/clients/trading/__generated__/models/OrderResponse.ts +13 -0
  158. package/src/clients/trading/__generated__/models/OrderStatus.ts +23 -0
  159. package/src/clients/trading/__generated__/models/OrderType.ts +11 -0
  160. package/src/clients/trading/__generated__/models/OrderTypeQuery.ts +12 -0
  161. package/src/clients/trading/__generated__/models/Permit.ts +13 -0
  162. package/src/clients/trading/__generated__/models/PermitAmount.ts +11 -0
  163. package/src/clients/trading/__generated__/models/PlanResponse.ts +75 -0
  164. package/src/clients/trading/__generated__/models/PlanStatus.ts +14 -0
  165. package/src/clients/trading/__generated__/models/PlanStep.ts +59 -0
  166. package/src/clients/trading/__generated__/models/PlanStepMethod.ts +12 -0
  167. package/src/clients/trading/__generated__/models/PlanStepPayloadType.ts +12 -0
  168. package/src/clients/trading/__generated__/models/PlanStepProof.ts +20 -0
  169. package/src/clients/trading/__generated__/models/PlanStepStatus.ts +14 -0
  170. package/src/clients/trading/__generated__/models/PlanStepType.ts +23 -0
  171. package/src/clients/trading/__generated__/models/Pool.ts +15 -0
  172. package/src/clients/trading/__generated__/models/PoolInfoRequest.ts +20 -0
  173. package/src/clients/trading/__generated__/models/PoolInfoResponse.ts +16 -0
  174. package/src/clients/trading/__generated__/models/PoolInformation.ts +44 -0
  175. package/src/clients/trading/__generated__/models/PoolParameters.ts +19 -0
  176. package/src/clients/trading/__generated__/models/PoolReferenceByProtocol.ts +12 -0
  177. package/src/clients/trading/__generated__/models/Position.ts +11 -0
  178. package/src/clients/trading/__generated__/models/PriorityInput.ts +12 -0
  179. package/src/clients/trading/__generated__/models/PriorityOrderInfo.ts +29 -0
  180. package/src/clients/trading/__generated__/models/PriorityOutput.ts +17 -0
  181. package/src/clients/trading/__generated__/models/PriorityQuote.ts +31 -0
  182. package/src/clients/trading/__generated__/models/ProtocolItems.ts +15 -0
  183. package/src/clients/trading/__generated__/models/Protocols.ts +9 -0
  184. package/src/clients/trading/__generated__/models/Quote.ts +14 -0
  185. package/src/clients/trading/__generated__/models/QuoteRequest.ts +41 -0
  186. package/src/clients/trading/__generated__/models/QuoteResponse.ts +19 -0
  187. package/src/clients/trading/__generated__/models/RequestId.ts +8 -0
  188. package/src/clients/trading/__generated__/models/Routing.ts +20 -0
  189. package/src/clients/trading/__generated__/models/RoutingPreference.ts +16 -0
  190. package/src/clients/trading/__generated__/models/SafetyLevel.ts +10 -0
  191. package/src/clients/trading/__generated__/models/ScopeData.ts +28 -0
  192. package/src/clients/trading/__generated__/models/SettledAmount.ts +14 -0
  193. package/src/clients/trading/__generated__/models/SortKey.ts +7 -0
  194. package/src/clients/trading/__generated__/models/SpreadOptimization.ts +11 -0
  195. package/src/clients/trading/__generated__/models/StepUpdate.ts +25 -0
  196. package/src/clients/trading/__generated__/models/SwapSafetyMode.ts +10 -0
  197. package/src/clients/trading/__generated__/models/SwapStatus.ts +11 -0
  198. package/src/clients/trading/__generated__/models/TokenInRoute.ts +20 -0
  199. package/src/clients/trading/__generated__/models/TokenProject.ts +13 -0
  200. package/src/clients/trading/__generated__/models/TokenProjectLogo.ts +8 -0
  201. package/src/clients/trading/__generated__/models/TradeType.ts +11 -0
  202. package/src/clients/trading/__generated__/models/TransactionFailureReason.ts +11 -0
  203. package/src/clients/trading/__generated__/models/TransactionHash.ts +8 -0
  204. package/src/clients/trading/__generated__/models/TransactionRequest.ts +29 -0
  205. package/src/clients/trading/__generated__/models/TransactionRequest5792.ts +25 -0
  206. package/src/clients/trading/__generated__/models/TruncatedPlanStep.ts +21 -0
  207. package/src/clients/trading/__generated__/models/UniversalRouterVersion.ts +8 -0
  208. package/src/clients/trading/__generated__/models/UpdatePlanRequest.ts +12 -0
  209. package/src/clients/trading/__generated__/models/Urgency.ts +12 -0
  210. package/src/clients/trading/__generated__/models/V2PoolInRoute.ts +19 -0
  211. package/src/clients/trading/__generated__/models/V2Reserve.ts +16 -0
  212. package/src/clients/trading/__generated__/models/V3PoolInRoute.ts +24 -0
  213. package/src/clients/trading/__generated__/models/V4PoolInRoute.ts +30 -0
  214. package/src/clients/trading/__generated__/models/WalletCheckDelegationRequestBody.ts +17 -0
  215. package/src/clients/trading/__generated__/models/WalletCheckDelegationResponseBody.ts +14 -0
  216. package/src/clients/trading/__generated__/models/WalletEncode7702RequestBody.ts +21 -0
  217. package/src/clients/trading/__generated__/models/WalletExecutionContext.ts +17 -0
  218. package/src/clients/trading/__generated__/models/WalletInfo.ts +22 -0
  219. package/src/clients/trading/__generated__/models/WalletProperties.ts +12 -0
  220. package/src/clients/trading/__generated__/models/WrapUnwrapQuote.ts +31 -0
  221. package/src/clients/trading/__generated__/models/additionalValidationContract.ts +9 -0
  222. package/src/clients/trading/__generated__/models/additionalValidationData.ts +9 -0
  223. package/src/clients/trading/__generated__/models/bps.ts +8 -0
  224. package/src/clients/trading/__generated__/models/bpsFee.ts +8 -0
  225. package/src/clients/trading/__generated__/models/bridgeTokenInChainIdParam.ts +6 -0
  226. package/src/clients/trading/__generated__/models/chainIdParam.ts +6 -0
  227. package/src/clients/trading/__generated__/models/claimerWalletAddress.ts +8 -0
  228. package/src/clients/trading/__generated__/models/contractAddress.ts +8 -0
  229. package/src/clients/trading/__generated__/models/cosignerAddress.ts +8 -0
  230. package/src/clients/trading/__generated__/models/cursorParam.ts +5 -0
  231. package/src/clients/trading/__generated__/models/deadline.ts +8 -0
  232. package/src/clients/trading/__generated__/models/encodedOrder.ts +8 -0
  233. package/src/clients/trading/__generated__/models/endAmount.ts +8 -0
  234. package/src/clients/trading/__generated__/models/erc20EthEnabledHeader.ts +8 -0
  235. package/src/clients/trading/__generated__/models/fillerParam.ts +9 -0
  236. package/src/clients/trading/__generated__/models/gasFee.ts +8 -0
  237. package/src/clients/trading/__generated__/models/gasFeeInCurrency.ts +8 -0
  238. package/src/clients/trading/__generated__/models/gasFeeUSD.ts +8 -0
  239. package/src/clients/trading/__generated__/models/gasLimit.ts +8 -0
  240. package/src/clients/trading/__generated__/models/gasPrice.ts +8 -0
  241. package/src/clients/trading/__generated__/models/generatePermitAsTransaction.ts +8 -0
  242. package/src/clients/trading/__generated__/models/includeGasInfo.ts +8 -0
  243. package/src/clients/trading/__generated__/models/inputToken.ts +8 -0
  244. package/src/clients/trading/__generated__/models/isSpam.ts +8 -0
  245. package/src/clients/trading/__generated__/models/limitParam.ts +5 -0
  246. package/src/clients/trading/__generated__/models/liquidity.ts +8 -0
  247. package/src/clients/trading/__generated__/models/lpPoolFee.ts +8 -0
  248. package/src/clients/trading/__generated__/models/lpTickCurrent.ts +8 -0
  249. package/src/clients/trading/__generated__/models/maxFeePerGas.ts +8 -0
  250. package/src/clients/trading/__generated__/models/maxPriorityFeePerGas.ts +8 -0
  251. package/src/clients/trading/__generated__/models/minAmount.ts +8 -0
  252. package/src/clients/trading/__generated__/models/nonce.ts +8 -0
  253. package/src/clients/trading/__generated__/models/orderId.ts +8 -0
  254. package/src/clients/trading/__generated__/models/orderIdParam.ts +6 -0
  255. package/src/clients/trading/__generated__/models/orderIdsParam.ts +9 -0
  256. package/src/clients/trading/__generated__/models/orderStatusParam.ts +9 -0
  257. package/src/clients/trading/__generated__/models/orderTypeParam.ts +9 -0
  258. package/src/clients/trading/__generated__/models/outputToken.ts +8 -0
  259. package/src/clients/trading/__generated__/models/poolFee.ts +8 -0
  260. package/src/clients/trading/__generated__/models/portionAmount.ts +8 -0
  261. package/src/clients/trading/__generated__/models/portionAmountReceiverAddress.ts +8 -0
  262. package/src/clients/trading/__generated__/models/portionBips.ts +8 -0
  263. package/src/clients/trading/__generated__/models/quoteId.ts +8 -0
  264. package/src/clients/trading/__generated__/models/receiverWalletAddress.ts +8 -0
  265. package/src/clients/trading/__generated__/models/senderWalletAddress.ts +8 -0
  266. package/src/clients/trading/__generated__/models/slippageTolerance.ts +14 -0
  267. package/src/clients/trading/__generated__/models/sortKeyParam.ts +9 -0
  268. package/src/clients/trading/__generated__/models/sortParam.ts +8 -0
  269. package/src/clients/trading/__generated__/models/sqrtRatioX96.ts +8 -0
  270. package/src/clients/trading/__generated__/models/startAmount.ts +8 -0
  271. package/src/clients/trading/__generated__/models/swapperParam.ts +9 -0
  272. package/src/clients/trading/__generated__/models/tickCurrent.ts +8 -0
  273. package/src/clients/trading/__generated__/models/tickSpacing.ts +8 -0
  274. package/src/clients/trading/__generated__/models/tokenAmount.ts +8 -0
  275. package/src/clients/trading/__generated__/models/tokenInParam.ts +6 -0
  276. package/src/clients/trading/__generated__/models/tokenSymbol.ts +8 -0
  277. package/src/clients/trading/__generated__/models/transactionHashesParam.ts +9 -0
  278. package/src/clients/trading/__generated__/models/universalRouterVersionHeader.ts +9 -0
  279. package/src/clients/trading/__generated__/services/ApprovalService.ts +39 -0
  280. package/src/clients/trading/__generated__/services/DefaultService.ts +46 -0
  281. package/src/clients/trading/__generated__/services/IndicativeQuoteService.ts +39 -0
  282. package/src/clients/trading/__generated__/services/LimitOrderQuoteService.ts +37 -0
  283. package/src/clients/trading/__generated__/services/LiquidityService.ts +239 -0
  284. package/src/clients/trading/__generated__/services/OrderService.ts +131 -0
  285. package/src/clients/trading/__generated__/services/PlanService.ts +76 -0
  286. package/src/clients/trading/__generated__/services/QuoteService.ts +58 -0
  287. package/src/clients/trading/__generated__/services/SendService.ts +37 -0
  288. package/src/clients/trading/__generated__/services/SwapService.ts +161 -0
  289. package/src/clients/trading/__generated__/services/SwappableTokensService.ts +42 -0
  290. package/src/clients/trading/__generated__/services/WalletCheckDelegationService.ts +37 -0
  291. package/src/clients/trading/__generated__/services/WalletEncode7702Service.ts +37 -0
  292. package/src/clients/trading/api.json +1 -0
  293. package/src/clients/trading/createTradingApiClient.ts +328 -0
  294. package/src/clients/trading/tradeTypes.ts +51 -0
  295. package/src/clients/trading/types.ts +72 -0
  296. package/src/clients/unitags/createUnitagsApiClient.test.ts +438 -0
  297. package/src/clients/unitags/createUnitagsApiClient.ts +214 -0
  298. package/src/clients/unitags/types.ts +122 -0
  299. package/src/components/ApiInit.test.tsx +364 -0
  300. package/src/components/ApiInit.tsx +71 -0
  301. package/src/connectRpc/base.ts +33 -0
  302. package/src/connectRpc/utils.ts +136 -0
  303. package/src/getEntryGatewayUrl.ts +46 -0
  304. package/src/getWebSocketUrl.ts +28 -0
  305. package/src/global.d.ts +2 -0
  306. package/src/hooks/index.ts +6 -0
  307. package/src/hooks/shared/types.ts +10 -0
  308. package/src/hooks/shared/useQueryWithImmediateGarbageCollection.ts +90 -0
  309. package/src/hooks/use-token-list.ts +52 -0
  310. package/src/hooks/use-token-price.ts +82 -0
  311. package/src/hooks/useIsSessionInitialized.ts +17 -0
  312. package/src/index.ts +318 -0
  313. package/src/provideDeviceIdService.ts +25 -0
  314. package/src/provideLuxIdentifierService.ts +25 -0
  315. package/src/provideSessionService.native.ts +46 -0
  316. package/src/provideSessionService.ts +13 -0
  317. package/src/provideSessionService.web.ts +87 -0
  318. package/src/provideSessionStorage.ts +21 -0
  319. package/src/session/createSessionTransport.test.ts +79 -0
  320. package/src/session/createSessionTransport.ts +107 -0
  321. package/src/session/createWithSessionRetry.ts +33 -0
  322. package/src/session/index.ts +12 -0
  323. package/src/storage/createExtensionStorageDriver.ts +29 -0
  324. package/src/storage/createNativeStorageDriver.ts +19 -0
  325. package/src/storage/createWebStorageDriver.ts +17 -0
  326. package/src/storage/getStorageDriver.native.ts +6 -0
  327. package/src/storage/getStorageDriver.ts +8 -0
  328. package/src/storage/getStorageDriver.web.ts +11 -0
  329. package/src/storage/types.ts +9 -0
  330. package/src/transport.ts +85 -0
  331. package/stubs/privy-service-connect.d.ts +3 -0
  332. package/stubs/privy-service-pb.d.ts +60 -0
  333. package/tsconfig.json +37 -0
  334. package/tsconfig.lint.json +8 -0
  335. package/tsconfig.spec.json +8 -0
  336. package/vitest.config.ts +14 -0
@@ -0,0 +1,438 @@
1
+ import { beforeEach, describe, expect, it, type Mock, vi } from 'vitest'
2
+ import '@luxfi/utilities/src/logger/mocks'
3
+
4
+ vi.mock('@luxfi/config', () => ({
5
+ getConfig: vi.fn(() => ({
6
+ unitagsApiUrlOverride: undefined,
7
+ })),
8
+ }))
9
+
10
+ vi.mock('@luxfi/api/src/clients/base/urls', () => ({
11
+ getCloudflareApiBaseUrl: vi.fn(() => 'https://api.test.com'),
12
+ TrafficFlows: {
13
+ Unitags: 'unitags',
14
+ },
15
+ }))
16
+
17
+ vi.mock('@luxfi/api/src/clients/base/createFetchClient', () => ({
18
+ createFetchClient: vi.fn(() => ({
19
+ get: vi.fn(),
20
+ post: vi.fn(),
21
+ put: vi.fn(),
22
+ delete: vi.fn(),
23
+ })),
24
+ }))
25
+
26
+ vi.mock('@luxfi/api/src/clients/base/auth', () => ({
27
+ createSignedRequestBody: vi.fn(),
28
+ createSignedRequestParams: vi.fn(),
29
+ }))
30
+
31
+ vi.mock('@luxfi/api/src/clients/base/utils', () => ({
32
+ createFetcher: vi.fn(),
33
+ }))
34
+
35
+ type FetcherConfig = {
36
+ client: unknown
37
+ method: string
38
+ url: string
39
+ transformRequest?: (args: { params: unknown; url: string }) => Promise<{
40
+ url?: string
41
+ headers?: HeadersInit
42
+ params?: unknown
43
+ }>
44
+ transformResponse?: (response: unknown) => unknown
45
+ }
46
+
47
+ const mockFetchClient = {
48
+ context: vi.fn(),
49
+ fetch: vi.fn(),
50
+ get: vi.fn(),
51
+ post: vi.fn(),
52
+ put: vi.fn(),
53
+ delete: vi.fn(),
54
+ patch: vi.fn(),
55
+ }
56
+
57
+ // Import after mocks are set up
58
+ import { createSignedRequestBody, createSignedRequestParams } from '@luxfi/api/src/clients/base/auth'
59
+ import { createFetcher } from '@luxfi/api/src/clients/base/utils'
60
+
61
+ describe('UnitagsApiClient', () => {
62
+ const mockCreateFetcher = createFetcher as unknown as Mock
63
+ const mockCreateSignedRequestBody = createSignedRequestBody as unknown as Mock
64
+ const mockCreateSignedRequestParams = createSignedRequestParams as unknown as Mock
65
+
66
+ beforeEach(() => {
67
+ vi.clearAllMocks()
68
+
69
+ mockCreateSignedRequestBody.mockResolvedValue({
70
+ requestBody: {
71
+ test: 'data',
72
+ 'x-uni-address': '0x123',
73
+ 'x-uni-timestamp': 1234567890,
74
+ } as any,
75
+ signature: 'mock-signature',
76
+ })
77
+
78
+ mockCreateSignedRequestParams.mockResolvedValue({
79
+ requestParams: {
80
+ test: 'data',
81
+ 'x-uni-address': '0x123',
82
+ 'x-uni-timestamp': 1234567890,
83
+ } as any,
84
+ signature: 'mock-signature',
85
+ })
86
+ })
87
+
88
+ describe('transformRequest functions', () => {
89
+ let fetcherConfigs: FetcherConfig[]
90
+
91
+ beforeEach(async () => {
92
+ vi.resetModules()
93
+ mockCreateFetcher.mockClear()
94
+ const { createUnitagsApiClient } = await import('./createUnitagsApiClient')
95
+
96
+ createUnitagsApiClient({ fetchClient: mockFetchClient })
97
+ fetcherConfigs = mockCreateFetcher.mock.calls.map((call) => call[0] as FetcherConfig)
98
+ })
99
+
100
+ it('should not have transformRequest for fetchUnitagsByAddresses', async () => {
101
+ const config = fetcherConfigs.find((c) => c.url === '/addresses')
102
+ expect(config?.transformRequest).toBeUndefined()
103
+ })
104
+
105
+ it('should transform claimUnitag request with signature', async () => {
106
+ const config = fetcherConfigs.find((c) => c.url === '/username' && c.method === 'post')
107
+ expect(config?.transformRequest).toBeDefined()
108
+
109
+ const params = {
110
+ data: { username: 'testuser', deviceId: 'device123' },
111
+ address: '0x123',
112
+ signMessage: vi.fn().mockResolvedValue('mock-signature'),
113
+ }
114
+
115
+ const result = await config!.transformRequest!({
116
+ url: '/username',
117
+ params,
118
+ })
119
+
120
+ expect(mockCreateSignedRequestBody).toHaveBeenCalledWith({
121
+ data: params.data,
122
+ address: params.address,
123
+ signMessage: params.signMessage,
124
+ })
125
+
126
+ expect(result).toEqual({
127
+ params: {
128
+ test: 'data',
129
+ 'x-uni-address': '0x123',
130
+ 'x-uni-timestamp': 1234567890,
131
+ },
132
+ headers: {
133
+ 'x-uni-sig': 'mock-signature',
134
+ },
135
+ })
136
+ })
137
+
138
+ it('should transform updateUnitagMetadata request with URL replacement', async () => {
139
+ const config = fetcherConfigs.find((c) => c.url === '/username/:username/metadata')
140
+ expect(config?.transformRequest).toBeDefined()
141
+
142
+ const params = {
143
+ username: 'testuser',
144
+ data: { metadata: { description: 'updated' } },
145
+ address: '0x123',
146
+ signMessage: vi.fn().mockResolvedValue('mock-signature'),
147
+ }
148
+
149
+ const result = await config!.transformRequest!({
150
+ url: '/username/:username/metadata',
151
+ params,
152
+ })
153
+
154
+ expect(mockCreateSignedRequestBody).toHaveBeenCalledWith({
155
+ data: params.data,
156
+ address: params.address,
157
+ signMessage: params.signMessage,
158
+ })
159
+
160
+ expect(result).toEqual({
161
+ url: '/username/testuser/metadata',
162
+ params: {
163
+ test: 'data',
164
+ 'x-uni-address': '0x123',
165
+ 'x-uni-timestamp': 1234567890,
166
+ },
167
+ headers: {
168
+ 'x-uni-sig': 'mock-signature',
169
+ },
170
+ })
171
+ })
172
+
173
+ it('should transform changeUnitag request with signature', async () => {
174
+ const config = fetcherConfigs.find((c) => c.url === '/username/change')
175
+ expect(config?.transformRequest).toBeDefined()
176
+
177
+ const params = {
178
+ data: { newUsername: 'newuser' },
179
+ address: '0x123',
180
+ signMessage: vi.fn().mockResolvedValue('mock-signature'),
181
+ }
182
+
183
+ const result = await config!.transformRequest!({
184
+ url: '/username/change',
185
+ params,
186
+ })
187
+
188
+ expect(mockCreateSignedRequestBody).toHaveBeenCalledWith({
189
+ data: params.data,
190
+ address: params.address,
191
+ signMessage: params.signMessage,
192
+ })
193
+
194
+ expect(result).toEqual({
195
+ params: {
196
+ test: 'data',
197
+ 'x-uni-address': '0x123',
198
+ 'x-uni-timestamp': 1234567890,
199
+ },
200
+ headers: {
201
+ 'x-uni-sig': 'mock-signature',
202
+ },
203
+ })
204
+ })
205
+
206
+ it('should transform deleteUnitag request with signature', async () => {
207
+ const config = fetcherConfigs.find((c) => c.url === '/username' && c.method === 'delete')
208
+ expect(config?.transformRequest).toBeDefined()
209
+
210
+ const params = {
211
+ data: { username: 'testuser' },
212
+ address: '0x123',
213
+ signMessage: vi.fn().mockResolvedValue('mock-signature'),
214
+ }
215
+
216
+ const result = await config!.transformRequest!({
217
+ url: '/username',
218
+ params,
219
+ })
220
+
221
+ expect(mockCreateSignedRequestBody).toHaveBeenCalledWith({
222
+ data: params.data,
223
+ address: params.address,
224
+ signMessage: params.signMessage,
225
+ })
226
+
227
+ expect(result).toEqual({
228
+ params: {
229
+ test: 'data',
230
+ 'x-uni-address': '0x123',
231
+ 'x-uni-timestamp': 1234567890,
232
+ },
233
+ headers: {
234
+ 'x-uni-sig': 'mock-signature',
235
+ },
236
+ })
237
+ })
238
+
239
+ it('should transform getUnitagAvatarUploadUrl request with createSignedRequestParams', async () => {
240
+ const config = fetcherConfigs.find((c) => c.url === '/username/avatar-upload-url')
241
+ expect(config?.transformRequest).toBeDefined()
242
+
243
+ const params = {
244
+ data: { username: 'testuser' },
245
+ address: '0x123',
246
+ signMessage: vi.fn().mockResolvedValue('mock-signature'),
247
+ }
248
+
249
+ const result = await config!.transformRequest!({
250
+ url: '/username/avatar-upload-url',
251
+ params,
252
+ })
253
+
254
+ expect(mockCreateSignedRequestParams).toHaveBeenCalledWith({
255
+ data: params.data,
256
+ address: params.address,
257
+ signMessage: params.signMessage,
258
+ })
259
+
260
+ expect(result).toEqual({
261
+ params: {
262
+ test: 'data',
263
+ 'x-uni-address': '0x123',
264
+ 'x-uni-timestamp': 1234567890,
265
+ },
266
+ headers: {
267
+ 'x-uni-sig': 'mock-signature',
268
+ },
269
+ })
270
+ })
271
+ })
272
+
273
+ describe('transformResponse functions', () => {
274
+ let fetcherConfigs: FetcherConfig[]
275
+
276
+ beforeEach(async () => {
277
+ vi.resetModules()
278
+ mockCreateFetcher.mockClear()
279
+ const { createUnitagsApiClient } = await import('./createUnitagsApiClient')
280
+
281
+ createUnitagsApiClient({ fetchClient: mockFetchClient })
282
+ fetcherConfigs = mockCreateFetcher.mock.calls.map((call) => call[0] as FetcherConfig)
283
+ })
284
+
285
+ it('should sanitize avatar URL in fetchUsername response', () => {
286
+ const config = fetcherConfigs.find((c) => c.url === '/username' && c.method === 'get')
287
+ expect(config?.transformResponse).toBeDefined()
288
+
289
+ const response = {
290
+ available: true,
291
+ requiresEnsMatch: false,
292
+ metadata: { avatar: 'https://example.com/avatar.png', description: 'test' },
293
+ }
294
+ const result = config!.transformResponse!(response) as typeof response
295
+ expect(result.metadata.avatar).toBe('https://example.com/avatar.png')
296
+
297
+ const maliciousResponse = {
298
+ available: true,
299
+ requiresEnsMatch: false,
300
+ // eslint-disable-next-line no-script-url
301
+ metadata: { avatar: 'javascript:alert(1)', description: 'test' },
302
+ }
303
+ const sanitizedResult = config!.transformResponse!(maliciousResponse) as typeof response
304
+ expect(sanitizedResult.metadata.avatar).toBeUndefined()
305
+ })
306
+
307
+ it('should sanitize avatar URL in fetchAddress response', () => {
308
+ const config = fetcherConfigs.find((c) => c.url === '/address')
309
+ expect(config?.transformResponse).toBeDefined()
310
+
311
+ const response = {
312
+ username: 'test',
313
+ metadata: { avatar: 'https://example.com/avatar.png' },
314
+ }
315
+ const result = config!.transformResponse!(response) as typeof response
316
+ expect(result.metadata.avatar).toBe('https://example.com/avatar.png')
317
+
318
+ const maliciousResponse = {
319
+ username: 'test',
320
+ metadata: { avatar: 'ipfs://QmHash123' },
321
+ }
322
+ const sanitizedResult = config!.transformResponse!(maliciousResponse) as typeof response
323
+ expect(sanitizedResult.metadata.avatar).toBeUndefined()
324
+ })
325
+
326
+ it('should sanitize avatar URLs in fetchUnitagsByAddresses response', () => {
327
+ const config = fetcherConfigs.find((c) => c.url === '/addresses')
328
+ expect(config?.transformResponse).toBeDefined()
329
+
330
+ const response = {
331
+ usernames: {
332
+ '0x123': { username: 'user1', metadata: { avatar: 'https://example.com/1.png' } },
333
+ '0x456': { username: 'user2', metadata: { avatar: 'data:image/png;base64,abc' } },
334
+ },
335
+ }
336
+ const result = config!.transformResponse!(response) as typeof response
337
+ expect(result.usernames['0x123'].metadata.avatar).toBe('https://example.com/1.png')
338
+ expect(result.usernames['0x456'].metadata.avatar).toBeUndefined()
339
+ })
340
+
341
+ it('should sanitize avatar URL in updateUnitagMetadata response', () => {
342
+ const config = fetcherConfigs.find((c) => c.url === '/username/:username/metadata')
343
+ expect(config?.transformResponse).toBeDefined()
344
+
345
+ const response = {
346
+ success: true,
347
+ metadata: { avatar: 'https://example.com/avatar.png' },
348
+ }
349
+ const result = config!.transformResponse!(response) as typeof response
350
+ expect(result.metadata.avatar).toBe('https://example.com/avatar.png')
351
+
352
+ const maliciousResponse = {
353
+ success: true,
354
+ metadata: { avatar: 'file:///etc/passwd' },
355
+ }
356
+ const sanitizedResult = config!.transformResponse!(maliciousResponse) as typeof response
357
+ expect(sanitizedResult.metadata.avatar).toBeUndefined()
358
+ })
359
+
360
+ it('should not have transformResponse for endpoints without avatar data', () => {
361
+ const claimEligibility = fetcherConfigs.find((c) => c.url === '/claim/eligibility')
362
+ expect(claimEligibility?.transformResponse).toBeUndefined()
363
+
364
+ const claimUnitag = fetcherConfigs.find((c) => c.url === '/username' && c.method === 'post')
365
+ expect(claimUnitag?.transformResponse).toBeUndefined()
366
+
367
+ const changeUnitag = fetcherConfigs.find((c) => c.url === '/username/change')
368
+ expect(changeUnitag?.transformResponse).toBeUndefined()
369
+
370
+ const deleteUnitag = fetcherConfigs.find((c) => c.url === '/username' && c.method === 'delete')
371
+ expect(deleteUnitag?.transformResponse).toBeUndefined()
372
+
373
+ const avatarUploadUrl = fetcherConfigs.find((c) => c.url === '/username/avatar-upload-url')
374
+ expect(avatarUploadUrl?.transformResponse).toBeUndefined()
375
+ })
376
+ })
377
+
378
+ describe('client instance methods', () => {
379
+ let mockFetchers: Record<string, Mock>
380
+
381
+ beforeEach(() => {
382
+ mockFetchers = {}
383
+ mockCreateFetcher.mockImplementation((config: any) => {
384
+ const key = `${config.method}-${config.url}`
385
+ const fetcher = vi.fn()
386
+ mockFetchers[key] = fetcher
387
+ return fetcher as any
388
+ })
389
+ })
390
+
391
+ it('should create client with all fetcher functions', async () => {
392
+ vi.resetModules()
393
+ mockCreateFetcher.mockClear()
394
+ const { createUnitagsApiClient } = await import('./createUnitagsApiClient')
395
+ const client = createUnitagsApiClient({ fetchClient: mockFetchClient })
396
+
397
+ expect(client.fetchUsername).toBeDefined()
398
+ expect(client.fetchAddress).toBeDefined()
399
+ expect(client.fetchUnitagsByAddresses).toBeDefined()
400
+ expect(client.fetchClaimEligibility).toBeDefined()
401
+ expect(client.claimUnitag).toBeDefined()
402
+ expect(client.updateUnitagMetadata).toBeDefined()
403
+ expect(client.changeUnitag).toBeDefined()
404
+ expect(client.deleteUnitag).toBeDefined()
405
+ expect(client.getUnitagAvatarUploadUrl).toBeDefined()
406
+ })
407
+
408
+ it('should call the correct fetcher when using client methods', async () => {
409
+ // Clear and reset mocks
410
+ vi.resetModules()
411
+ vi.clearAllMocks()
412
+ vi.resetModules() // Reset module cache
413
+ mockFetchers = {}
414
+
415
+ // Mock implementation that stores fetchers
416
+ mockCreateFetcher.mockImplementation((config: any) => {
417
+ const key = `${config.method}-${config.url}`
418
+ const fetcher = vi.fn()
419
+ mockFetchers[key] = fetcher
420
+ return fetcher as any
421
+ })
422
+
423
+ const { createUnitagsApiClient } = await import('./createUnitagsApiClient')
424
+ const client = createUnitagsApiClient({ fetchClient: mockFetchClient })
425
+
426
+ // Ensure the fetcher was created
427
+ expect(mockFetchers['get-/username']).toBeDefined()
428
+
429
+ // Test fetchUsername
430
+ const usernameResponse = { username: 'test', address: '0x123' }
431
+ mockFetchers['get-/username']?.mockResolvedValue(usernameResponse)
432
+
433
+ const result = await client.fetchUsername({ username: 'test' })
434
+ expect(mockFetchers['get-/username']).toHaveBeenCalledWith({ username: 'test' })
435
+ expect(result).toEqual(usernameResponse)
436
+ })
437
+ })
438
+ })
@@ -0,0 +1,214 @@
1
+ import {
2
+ createSignedRequestBody,
3
+ createSignedRequestParams,
4
+ type SignedRequestParams,
5
+ } from '@luxexchange/api/src/clients/base/auth'
6
+ import { type FetchClient } from '@luxexchange/api/src/clients/base/types'
7
+ import { createFetcher } from '@luxexchange/api/src/clients/base/utils'
8
+ import {
9
+ type ProfileMetadata,
10
+ type UnitagAddressesRequest,
11
+ type UnitagAddressesResponse,
12
+ type UnitagAddressRequest,
13
+ type UnitagAddressResponse,
14
+ type UnitagChangeUsernameRequestBody,
15
+ type UnitagClaimEligibilityRequest,
16
+ type UnitagClaimEligibilityResponse,
17
+ type UnitagClaimUsernameRequestBody,
18
+ type UnitagDeleteUsernameRequestBody,
19
+ type UnitagGetAvatarUploadUrlResponse,
20
+ type UnitagResponse,
21
+ type UnitagUpdateMetadataRequestBody,
22
+ type UnitagUpdateMetadataResponse,
23
+ type UnitagUsernameRequest,
24
+ type UnitagUsernameResponse,
25
+ } from '@luxexchange/api/src/clients/unitags/types'
26
+ import { sanitizeAvatarUrl } from '@luxfi/utilities/src/format/urls'
27
+
28
+ const UNI_SIG_HEADER_KEY = 'x-uni-sig'
29
+
30
+ type UnitagsApiClientFetchersContext = {
31
+ fetchClient: FetchClient
32
+ }
33
+
34
+ export type UnitagsApiClientType = {
35
+ fetchUsername: (params: UnitagUsernameRequest) => Promise<UnitagUsernameResponse>
36
+ fetchAddress: (params: UnitagAddressRequest) => Promise<UnitagAddressResponse>
37
+ fetchUnitagsByAddresses: (params: UnitagAddressesRequest) => Promise<UnitagAddressesResponse>
38
+ fetchClaimEligibility: (params: UnitagClaimEligibilityRequest) => Promise<UnitagClaimEligibilityResponse>
39
+ claimUnitag: (params: SignedRequestParams<UnitagClaimUsernameRequestBody>) => Promise<UnitagResponse>
40
+ updateUnitagMetadata: (
41
+ params: { username: string } & SignedRequestParams<UnitagUpdateMetadataRequestBody>,
42
+ ) => Promise<UnitagUpdateMetadataResponse>
43
+ changeUnitag: (params: SignedRequestParams<UnitagChangeUsernameRequestBody>) => Promise<UnitagResponse>
44
+ deleteUnitag: (params: SignedRequestParams<UnitagDeleteUsernameRequestBody>) => Promise<UnitagResponse>
45
+ getUnitagAvatarUploadUrl: (
46
+ params: SignedRequestParams<{ username: string }>,
47
+ ) => Promise<UnitagGetAvatarUploadUrlResponse>
48
+ }
49
+
50
+ export function createUnitagsApiClient(ctx: UnitagsApiClientFetchersContext): UnitagsApiClientType {
51
+ const client = ctx.fetchClient
52
+ const fetchUsername = createFetcher<UnitagUsernameRequest, UnitagUsernameResponse>({
53
+ client,
54
+ method: 'get',
55
+ url: '/username',
56
+ transformResponse: sanitizeMetadataResponse,
57
+ })
58
+ const fetchAddress = createFetcher<UnitagAddressRequest, UnitagAddressResponse>({
59
+ client,
60
+ method: 'get',
61
+ url: '/address',
62
+ transformResponse: sanitizeMetadataResponse,
63
+ })
64
+ const fetchUnitagsByAddresses = createFetcher<UnitagAddressesRequest, UnitagAddressesResponse>({
65
+ client,
66
+ method: 'get',
67
+ url: '/addresses',
68
+ transformResponse: (response) => ({
69
+ ...response,
70
+ usernames: Object.fromEntries(
71
+ Object.entries(response.usernames).map(([address, data]) => [
72
+ address,
73
+ { ...data, metadata: sanitizeProfileMetadata(data.metadata) },
74
+ ]),
75
+ ),
76
+ }),
77
+ })
78
+ const fetchClaimEligibility = createFetcher<UnitagClaimEligibilityRequest, UnitagClaimEligibilityResponse>({
79
+ client,
80
+ method: 'get',
81
+ url: '/claim/eligibility',
82
+ })
83
+
84
+ // Post requests with signature authentication
85
+ const claimUnitag = createFetcher<SignedRequestParams<UnitagClaimUsernameRequestBody>, UnitagResponse>({
86
+ client,
87
+ method: 'post',
88
+ url: '/username',
89
+ transformRequest: async (request) => {
90
+ const { data, address, signMessage } = request.params
91
+ const { requestBody, signature } = await createSignedRequestBody<UnitagClaimUsernameRequestBody>({
92
+ data,
93
+ address,
94
+ signMessage,
95
+ })
96
+ return {
97
+ params: requestBody,
98
+ headers: {
99
+ [UNI_SIG_HEADER_KEY]: signature,
100
+ },
101
+ }
102
+ },
103
+ })
104
+ const updateUnitagMetadata = createFetcher<
105
+ { username: string } & SignedRequestParams<UnitagUpdateMetadataRequestBody>,
106
+ UnitagUpdateMetadataResponse
107
+ >({
108
+ client,
109
+ method: 'put',
110
+ url: '/username/:username/metadata',
111
+ transformRequest: async (request) => {
112
+ const { data, address, signMessage } = request.params
113
+ const { requestBody, signature } = await createSignedRequestBody<UnitagUpdateMetadataRequestBody>({
114
+ data,
115
+ address,
116
+ signMessage,
117
+ })
118
+ return {
119
+ url: request.url.replace(':username', request.params.username),
120
+ params: requestBody,
121
+ headers: {
122
+ [UNI_SIG_HEADER_KEY]: signature,
123
+ },
124
+ }
125
+ },
126
+ transformResponse: sanitizeMetadataResponse,
127
+ })
128
+ const changeUnitag = createFetcher<SignedRequestParams<UnitagChangeUsernameRequestBody>, UnitagResponse>({
129
+ client,
130
+ method: 'post',
131
+ url: '/username/change',
132
+ transformRequest: async (request) => {
133
+ const { data, address, signMessage } = request.params
134
+ const { requestBody, signature } = await createSignedRequestBody<UnitagChangeUsernameRequestBody>({
135
+ data,
136
+ address,
137
+ signMessage,
138
+ })
139
+ return {
140
+ params: requestBody,
141
+ headers: {
142
+ [UNI_SIG_HEADER_KEY]: signature,
143
+ },
144
+ }
145
+ },
146
+ })
147
+ const deleteUnitag = createFetcher<SignedRequestParams<UnitagDeleteUsernameRequestBody>, UnitagResponse>({
148
+ client,
149
+ method: 'delete',
150
+ url: '/username',
151
+ transformRequest: async (request) => {
152
+ const { data, address, signMessage } = request.params
153
+ const { requestBody, signature } = await createSignedRequestBody<UnitagDeleteUsernameRequestBody>({
154
+ data,
155
+ address,
156
+ signMessage,
157
+ })
158
+ return {
159
+ params: requestBody,
160
+ headers: {
161
+ [UNI_SIG_HEADER_KEY]: signature,
162
+ },
163
+ }
164
+ },
165
+ })
166
+ const getUnitagAvatarUploadUrl = createFetcher<
167
+ SignedRequestParams<{ username: string }>,
168
+ UnitagGetAvatarUploadUrlResponse
169
+ >({
170
+ client,
171
+ method: 'get',
172
+ url: '/username/avatar-upload-url',
173
+ transformRequest: async (request) => {
174
+ const { data, address, signMessage } = request.params
175
+ const { requestParams, signature } = await createSignedRequestParams<{ username: string }>({
176
+ data,
177
+ address,
178
+ signMessage,
179
+ })
180
+ return {
181
+ params: requestParams,
182
+ headers: {
183
+ [UNI_SIG_HEADER_KEY]: signature,
184
+ },
185
+ }
186
+ },
187
+ })
188
+
189
+ return {
190
+ fetchUsername,
191
+ fetchAddress,
192
+ fetchUnitagsByAddresses,
193
+ fetchClaimEligibility,
194
+ claimUnitag,
195
+ updateUnitagMetadata,
196
+ changeUnitag,
197
+ deleteUnitag,
198
+ getUnitagAvatarUploadUrl,
199
+ }
200
+ }
201
+
202
+ function sanitizeProfileMetadata(metadata: ProfileMetadata | undefined): ProfileMetadata | undefined {
203
+ if (!metadata) {
204
+ return metadata
205
+ }
206
+ return {
207
+ ...metadata,
208
+ avatar: sanitizeAvatarUrl(metadata.avatar ?? null) ?? undefined,
209
+ }
210
+ }
211
+
212
+ function sanitizeMetadataResponse<T extends { metadata?: ProfileMetadata }>(response: T): T {
213
+ return { ...response, metadata: sanitizeProfileMetadata(response.metadata) }
214
+ }