intentkit 0.8.16.dev1__py3-none-any.whl → 0.8.17.dev2__py3-none-any.whl

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.

Potentially problematic release.


This version of intentkit might be problematic. Click here for more details.

Files changed (274) hide show
  1. intentkit/__init__.py +1 -1
  2. intentkit/abstracts/agent.py +4 -5
  3. intentkit/abstracts/engine.py +5 -5
  4. intentkit/abstracts/graph.py +6 -5
  5. intentkit/abstracts/skill.py +5 -5
  6. intentkit/abstracts/twitter.py +4 -5
  7. intentkit/clients/cdp.py +19 -77
  8. intentkit/clients/twitter.py +26 -34
  9. intentkit/clients/web3.py +1 -3
  10. intentkit/config/config.py +4 -0
  11. intentkit/core/agent.py +15 -15
  12. intentkit/core/asset.py +1 -2
  13. intentkit/core/client.py +1 -1
  14. intentkit/core/credit.py +19 -20
  15. intentkit/core/engine.py +2 -4
  16. intentkit/core/node.py +2 -1
  17. intentkit/core/prompt.py +3 -4
  18. intentkit/core/scheduler.py +1 -1
  19. intentkit/core/statistics.py +6 -7
  20. intentkit/models/agent.py +125 -92
  21. intentkit/models/agent_data.py +62 -36
  22. intentkit/models/app_setting.py +6 -6
  23. intentkit/models/chat.py +27 -24
  24. intentkit/models/conversation.py +8 -8
  25. intentkit/models/credit.py +62 -64
  26. intentkit/models/db.py +8 -7
  27. intentkit/models/db_mig.py +2 -2
  28. intentkit/models/llm.py +12 -14
  29. intentkit/models/redis.py +2 -3
  30. intentkit/models/skill.py +25 -27
  31. intentkit/models/skills.csv +29 -28
  32. intentkit/models/user.py +21 -22
  33. intentkit/skills/acolyt/ask.py +3 -4
  34. intentkit/skills/acolyt/base.py +1 -3
  35. intentkit/skills/aixbt/base.py +1 -3
  36. intentkit/skills/aixbt/projects.py +13 -13
  37. intentkit/skills/allora/base.py +1 -3
  38. intentkit/skills/allora/price.py +2 -3
  39. intentkit/skills/base.py +15 -22
  40. intentkit/skills/basename/__init__.py +3 -5
  41. intentkit/skills/carv/__init__.py +7 -8
  42. intentkit/skills/carv/base.py +6 -6
  43. intentkit/skills/carv/fetch_news.py +3 -3
  44. intentkit/skills/carv/onchain_query.py +4 -4
  45. intentkit/skills/carv/token_info_and_price.py +5 -5
  46. intentkit/skills/casino/base.py +1 -3
  47. intentkit/skills/casino/deck_draw.py +1 -2
  48. intentkit/skills/casino/deck_shuffle.py +1 -2
  49. intentkit/skills/casino/dice_roll.py +1 -2
  50. intentkit/skills/cdp/__init__.py +3 -5
  51. intentkit/skills/cdp/base.py +1 -3
  52. intentkit/skills/chainlist/base.py +1 -3
  53. intentkit/skills/chainlist/chain_lookup.py +18 -18
  54. intentkit/skills/common/base.py +1 -3
  55. intentkit/skills/common/current_time.py +1 -2
  56. intentkit/skills/cookiefun/base.py +1 -2
  57. intentkit/skills/cookiefun/get_account_details.py +7 -7
  58. intentkit/skills/cookiefun/get_account_feed.py +19 -19
  59. intentkit/skills/cookiefun/get_account_smart_followers.py +7 -7
  60. intentkit/skills/cookiefun/get_sectors.py +3 -3
  61. intentkit/skills/cookiefun/search_accounts.py +9 -9
  62. intentkit/skills/cryptocompare/api.py +2 -3
  63. intentkit/skills/cryptocompare/base.py +6 -6
  64. intentkit/skills/cryptocompare/fetch_news.py +3 -4
  65. intentkit/skills/cryptocompare/fetch_price.py +5 -6
  66. intentkit/skills/cryptocompare/fetch_top_exchanges.py +3 -4
  67. intentkit/skills/cryptocompare/fetch_top_market_cap.py +3 -4
  68. intentkit/skills/cryptocompare/fetch_top_volume.py +3 -4
  69. intentkit/skills/cryptocompare/fetch_trading_signals.py +4 -5
  70. intentkit/skills/cryptopanic/__init__.py +4 -4
  71. intentkit/skills/cryptopanic/base.py +1 -3
  72. intentkit/skills/cryptopanic/fetch_crypto_news.py +3 -5
  73. intentkit/skills/cryptopanic/fetch_crypto_sentiment.py +3 -3
  74. intentkit/skills/dapplooker/base.py +1 -3
  75. intentkit/skills/dapplooker/dapplooker_token_data.py +7 -7
  76. intentkit/skills/defillama/api.py +6 -9
  77. intentkit/skills/defillama/base.py +5 -6
  78. intentkit/skills/defillama/coins/fetch_batch_historical_prices.py +6 -8
  79. intentkit/skills/defillama/coins/fetch_block.py +4 -6
  80. intentkit/skills/defillama/coins/fetch_current_prices.py +6 -8
  81. intentkit/skills/defillama/coins/fetch_first_price.py +5 -7
  82. intentkit/skills/defillama/coins/fetch_historical_prices.py +7 -9
  83. intentkit/skills/defillama/coins/fetch_price_chart.py +7 -9
  84. intentkit/skills/defillama/coins/fetch_price_percentage.py +5 -7
  85. intentkit/skills/defillama/config/chains.py +1 -3
  86. intentkit/skills/defillama/fees/fetch_fees_overview.py +22 -24
  87. intentkit/skills/defillama/stablecoins/fetch_stablecoin_chains.py +14 -16
  88. intentkit/skills/defillama/stablecoins/fetch_stablecoin_charts.py +6 -8
  89. intentkit/skills/defillama/stablecoins/fetch_stablecoin_prices.py +3 -5
  90. intentkit/skills/defillama/stablecoins/fetch_stablecoins.py +5 -7
  91. intentkit/skills/defillama/tests/api_integration.test.py +1 -1
  92. intentkit/skills/defillama/tvl/fetch_chain_historical_tvl.py +2 -4
  93. intentkit/skills/defillama/tvl/fetch_chains.py +7 -9
  94. intentkit/skills/defillama/tvl/fetch_historical_tvl.py +2 -4
  95. intentkit/skills/defillama/tvl/fetch_protocol.py +30 -36
  96. intentkit/skills/defillama/tvl/fetch_protocol_current_tvl.py +1 -3
  97. intentkit/skills/defillama/tvl/fetch_protocols.py +35 -43
  98. intentkit/skills/defillama/volumes/fetch_dex_overview.py +40 -46
  99. intentkit/skills/defillama/volumes/fetch_dex_summary.py +33 -35
  100. intentkit/skills/defillama/volumes/fetch_options_overview.py +22 -26
  101. intentkit/skills/defillama/yields/fetch_pool_chart.py +8 -10
  102. intentkit/skills/defillama/yields/fetch_pools.py +24 -28
  103. intentkit/skills/dexscreener/__init__.py +2 -2
  104. intentkit/skills/dexscreener/base.py +3 -3
  105. intentkit/skills/dexscreener/get_pair_info.py +2 -2
  106. intentkit/skills/dexscreener/get_token_pairs.py +2 -2
  107. intentkit/skills/dexscreener/get_tokens_info.py +5 -5
  108. intentkit/skills/dexscreener/model/search_token_response.py +80 -82
  109. intentkit/skills/dexscreener/search_token.py +182 -182
  110. intentkit/skills/dexscreener/utils.py +15 -14
  111. intentkit/skills/dune_analytics/__init__.py +4 -4
  112. intentkit/skills/dune_analytics/base.py +1 -3
  113. intentkit/skills/dune_analytics/fetch_kol_buys.py +4 -4
  114. intentkit/skills/dune_analytics/fetch_nation_metrics.py +5 -5
  115. intentkit/skills/elfa/base.py +1 -3
  116. intentkit/skills/elfa/mention.py +19 -21
  117. intentkit/skills/elfa/stats.py +4 -4
  118. intentkit/skills/elfa/tokens.py +12 -12
  119. intentkit/skills/elfa/utils.py +25 -27
  120. intentkit/skills/enso/__init__.py +2 -2
  121. intentkit/skills/enso/base.py +5 -8
  122. intentkit/skills/enso/best_yield.py +4 -6
  123. intentkit/skills/enso/networks.py +1 -2
  124. intentkit/skills/enso/prices.py +1 -3
  125. intentkit/skills/enso/route.py +1 -3
  126. intentkit/skills/enso/tokens.py +1 -3
  127. intentkit/skills/enso/wallet.py +5 -5
  128. intentkit/skills/erc20/__init__.py +4 -6
  129. intentkit/skills/erc721/__init__.py +4 -6
  130. intentkit/skills/firecrawl/base.py +1 -3
  131. intentkit/skills/firecrawl/clear.py +1 -2
  132. intentkit/skills/firecrawl/crawl.py +9 -10
  133. intentkit/skills/firecrawl/query.py +1 -2
  134. intentkit/skills/firecrawl/scrape.py +7 -8
  135. intentkit/skills/firecrawl/utils.py +13 -13
  136. intentkit/skills/github/base.py +1 -3
  137. intentkit/skills/github/github_search.py +1 -2
  138. intentkit/skills/heurist/base.py +1 -3
  139. intentkit/skills/heurist/image_generation_animagine_xl.py +7 -8
  140. intentkit/skills/heurist/image_generation_arthemy_comics.py +7 -8
  141. intentkit/skills/heurist/image_generation_arthemy_real.py +7 -8
  142. intentkit/skills/heurist/image_generation_braindance.py +7 -8
  143. intentkit/skills/heurist/image_generation_cyber_realistic_xl.py +7 -8
  144. intentkit/skills/heurist/image_generation_flux_1_dev.py +7 -8
  145. intentkit/skills/heurist/image_generation_sdxl.py +7 -8
  146. intentkit/skills/http/base.py +1 -3
  147. intentkit/skills/http/get.py +7 -7
  148. intentkit/skills/http/post.py +9 -9
  149. intentkit/skills/http/put.py +9 -9
  150. intentkit/skills/lifi/__init__.py +4 -4
  151. intentkit/skills/lifi/base.py +1 -3
  152. intentkit/skills/lifi/token_execute.py +13 -13
  153. intentkit/skills/lifi/token_quote.py +6 -6
  154. intentkit/skills/lifi/utils.py +16 -16
  155. intentkit/skills/moralis/__init__.py +3 -3
  156. intentkit/skills/moralis/api.py +6 -7
  157. intentkit/skills/moralis/base.py +2 -4
  158. intentkit/skills/moralis/fetch_chain_portfolio.py +10 -11
  159. intentkit/skills/moralis/fetch_nft_portfolio.py +22 -22
  160. intentkit/skills/moralis/fetch_solana_portfolio.py +11 -12
  161. intentkit/skills/moralis/fetch_wallet_portfolio.py +8 -9
  162. intentkit/skills/morpho/__init__.py +4 -6
  163. intentkit/skills/nation/__init__.py +2 -2
  164. intentkit/skills/nation/base.py +1 -3
  165. intentkit/skills/nation/nft_check.py +3 -4
  166. intentkit/skills/onchain.py +2 -6
  167. intentkit/skills/openai/base.py +1 -3
  168. intentkit/skills/openai/dalle_image_generation.py +1 -3
  169. intentkit/skills/openai/gpt_image_generation.py +2 -3
  170. intentkit/skills/openai/gpt_image_to_image.py +2 -3
  171. intentkit/skills/openai/image_to_text.py +1 -2
  172. intentkit/skills/portfolio/base.py +6 -6
  173. intentkit/skills/portfolio/token_balances.py +21 -21
  174. intentkit/skills/portfolio/wallet_approvals.py +7 -7
  175. intentkit/skills/portfolio/wallet_defi_positions.py +3 -3
  176. intentkit/skills/portfolio/wallet_history.py +21 -21
  177. intentkit/skills/portfolio/wallet_net_worth.py +13 -13
  178. intentkit/skills/portfolio/wallet_nfts.py +19 -19
  179. intentkit/skills/portfolio/wallet_profitability.py +7 -7
  180. intentkit/skills/portfolio/wallet_profitability_summary.py +5 -5
  181. intentkit/skills/portfolio/wallet_stats.py +3 -3
  182. intentkit/skills/portfolio/wallet_swaps.py +19 -19
  183. intentkit/skills/pyth/__init__.py +3 -5
  184. intentkit/skills/slack/base.py +2 -4
  185. intentkit/skills/slack/get_channel.py +8 -8
  186. intentkit/skills/slack/get_message.py +9 -9
  187. intentkit/skills/slack/schedule_message.py +5 -5
  188. intentkit/skills/slack/send_message.py +3 -5
  189. intentkit/skills/supabase/base.py +1 -3
  190. intentkit/skills/supabase/delete_data.py +4 -4
  191. intentkit/skills/supabase/fetch_data.py +12 -12
  192. intentkit/skills/supabase/insert_data.py +4 -4
  193. intentkit/skills/supabase/invoke_function.py +6 -6
  194. intentkit/skills/supabase/update_data.py +6 -6
  195. intentkit/skills/supabase/upsert_data.py +4 -4
  196. intentkit/skills/superfluid/__init__.py +4 -6
  197. intentkit/skills/system/add_autonomous_task.py +8 -10
  198. intentkit/skills/system/edit_autonomous_task.py +12 -14
  199. intentkit/skills/system/list_autonomous_tasks.py +1 -3
  200. intentkit/skills/tavily/base.py +1 -3
  201. intentkit/skills/tavily/tavily_extract.py +1 -2
  202. intentkit/skills/tavily/tavily_search.py +1 -3
  203. intentkit/skills/token/base.py +5 -5
  204. intentkit/skills/token/erc20_transfers.py +19 -19
  205. intentkit/skills/token/token_analytics.py +3 -3
  206. intentkit/skills/token/token_price.py +13 -13
  207. intentkit/skills/token/token_search.py +9 -9
  208. intentkit/skills/twitter/base.py +3 -4
  209. intentkit/skills/twitter/follow_user.py +1 -2
  210. intentkit/skills/twitter/get_mentions.py +3 -4
  211. intentkit/skills/twitter/get_timeline.py +1 -2
  212. intentkit/skills/twitter/get_user_by_username.py +1 -2
  213. intentkit/skills/twitter/get_user_tweets.py +2 -3
  214. intentkit/skills/twitter/like_tweet.py +1 -2
  215. intentkit/skills/twitter/post_tweet.py +3 -4
  216. intentkit/skills/twitter/reply_tweet.py +3 -4
  217. intentkit/skills/twitter/retweet.py +1 -2
  218. intentkit/skills/twitter/search_tweets.py +1 -2
  219. intentkit/skills/unrealspeech/base.py +1 -3
  220. intentkit/skills/unrealspeech/text_to_speech.py +8 -8
  221. intentkit/skills/venice_audio/__init__.py +8 -9
  222. intentkit/skills/venice_audio/base.py +3 -4
  223. intentkit/skills/venice_audio/input.py +41 -41
  224. intentkit/skills/venice_audio/venice_audio.py +6 -6
  225. intentkit/skills/venice_image/__init__.py +5 -5
  226. intentkit/skills/venice_image/api.py +138 -138
  227. intentkit/skills/venice_image/base.py +3 -3
  228. intentkit/skills/venice_image/config.py +33 -35
  229. intentkit/skills/venice_image/image_enhance/image_enhance.py +2 -3
  230. intentkit/skills/venice_image/image_enhance/image_enhance_base.py +21 -23
  231. intentkit/skills/venice_image/image_enhance/image_enhance_input.py +38 -40
  232. intentkit/skills/venice_image/image_generation/image_generation_base.py +9 -9
  233. intentkit/skills/venice_image/image_generation/image_generation_fluently_xl.py +26 -26
  234. intentkit/skills/venice_image/image_generation/image_generation_flux_dev.py +27 -27
  235. intentkit/skills/venice_image/image_generation/image_generation_flux_dev_uncensored.py +26 -26
  236. intentkit/skills/venice_image/image_generation/image_generation_input.py +158 -158
  237. intentkit/skills/venice_image/image_generation/image_generation_lustify_sdxl.py +26 -26
  238. intentkit/skills/venice_image/image_generation/image_generation_pony_realism.py +26 -26
  239. intentkit/skills/venice_image/image_generation/image_generation_stable_diffusion_3_5.py +28 -28
  240. intentkit/skills/venice_image/image_generation/image_generation_venice_sd35.py +28 -28
  241. intentkit/skills/venice_image/image_upscale/image_upscale.py +3 -3
  242. intentkit/skills/venice_image/image_upscale/image_upscale_base.py +21 -23
  243. intentkit/skills/venice_image/image_upscale/image_upscale_input.py +22 -22
  244. intentkit/skills/venice_image/image_vision/image_vision.py +2 -2
  245. intentkit/skills/venice_image/image_vision/image_vision_base.py +17 -17
  246. intentkit/skills/venice_image/image_vision/image_vision_input.py +9 -9
  247. intentkit/skills/venice_image/utils.py +77 -78
  248. intentkit/skills/web_scraper/base.py +1 -3
  249. intentkit/skills/web_scraper/document_indexer.py +1 -2
  250. intentkit/skills/web_scraper/scrape_and_index.py +4 -5
  251. intentkit/skills/web_scraper/utils.py +25 -26
  252. intentkit/skills/web_scraper/website_indexer.py +10 -11
  253. intentkit/skills/weth/__init__.py +4 -6
  254. intentkit/skills/wow/__init__.py +4 -6
  255. intentkit/skills/x402/__init__.py +11 -3
  256. intentkit/skills/x402/ask_agent.py +12 -78
  257. intentkit/skills/x402/base.py +90 -0
  258. intentkit/skills/x402/http_request.py +117 -0
  259. intentkit/skills/x402/schema.json +15 -10
  260. intentkit/skills/xmtp/base.py +3 -3
  261. intentkit/skills/xmtp/price.py +2 -2
  262. intentkit/skills/xmtp/swap.py +2 -4
  263. intentkit/skills/xmtp/transfer.py +4 -6
  264. intentkit/utils/error.py +2 -2
  265. intentkit/utils/logging.py +2 -4
  266. intentkit/utils/s3.py +8 -9
  267. intentkit/utils/schema.py +5 -5
  268. intentkit/utils/slack_alert.py +7 -8
  269. {intentkit-0.8.16.dev1.dist-info → intentkit-0.8.17.dev2.dist-info}/METADATA +3 -4
  270. intentkit-0.8.17.dev2.dist-info/RECORD +464 -0
  271. intentkit/models/generator.py +0 -347
  272. intentkit-0.8.16.dev1.dist-info/RECORD +0 -464
  273. {intentkit-0.8.16.dev1.dist-info → intentkit-0.8.17.dev2.dist-info}/WHEEL +0 -0
  274. {intentkit-0.8.16.dev1.dist-info → intentkit-0.8.17.dev2.dist-info}/licenses/LICENSE +0 -0
@@ -1,7 +1,5 @@
1
1
  """Tool for fetching batch historical token prices via DeFi Llama API."""
2
2
 
3
- from typing import Dict, List, Optional, Type
4
-
5
3
  from pydantic import BaseModel, Field
6
4
 
7
5
  from intentkit.skills.defillama.api import fetch_batch_historical_prices
@@ -33,7 +31,7 @@ class TokenPriceHistory(BaseModel):
33
31
  """Model representing historical price data for a single token."""
34
32
 
35
33
  symbol: str = Field(..., description="Token symbol")
36
- prices: List[HistoricalPricePoint] = Field(
34
+ prices: list[HistoricalPricePoint] = Field(
37
35
  ..., description="List of historical price points"
38
36
  )
39
37
 
@@ -41,7 +39,7 @@ class TokenPriceHistory(BaseModel):
41
39
  class FetchBatchHistoricalPricesInput(BaseModel):
42
40
  """Input schema for fetching batch historical token prices."""
43
41
 
44
- coins_timestamps: Dict[str, List[int]] = Field(
42
+ coins_timestamps: dict[str, list[int]] = Field(
45
43
  ..., description="Dictionary mapping token identifiers to lists of timestamps"
46
44
  )
47
45
 
@@ -49,11 +47,11 @@ class FetchBatchHistoricalPricesInput(BaseModel):
49
47
  class FetchBatchHistoricalPricesResponse(BaseModel):
50
48
  """Response schema for batch historical token prices."""
51
49
 
52
- coins: Dict[str, TokenPriceHistory] = Field(
50
+ coins: dict[str, TokenPriceHistory] = Field(
53
51
  default_factory=dict,
54
52
  description="Historical token prices keyed by token identifier",
55
53
  )
56
- error: Optional[str] = Field(None, description="Error message if any")
54
+ error: str | None = Field(None, description="Error message if any")
57
55
 
58
56
 
59
57
  class DefiLlamaFetchBatchHistoricalPrices(DefiLlamaBaseTool):
@@ -78,10 +76,10 @@ class DefiLlamaFetchBatchHistoricalPrices(DefiLlamaBaseTool):
78
76
 
79
77
  name: str = "defillama_fetch_batch_historical_prices"
80
78
  description: str = FETCH_BATCH_HISTORICAL_PRICES_PROMPT
81
- args_schema: Type[BaseModel] = FetchBatchHistoricalPricesInput
79
+ args_schema: type[BaseModel] = FetchBatchHistoricalPricesInput
82
80
 
83
81
  async def _arun(
84
- self, coins_timestamps: Dict[str, List[int]]
82
+ self, coins_timestamps: dict[str, list[int]]
85
83
  ) -> FetchBatchHistoricalPricesResponse:
86
84
  """Fetch historical prices for the given tokens at specified timestamps.
87
85
 
@@ -1,7 +1,5 @@
1
1
  """Tool for fetching current block data via DeFi Llama API."""
2
2
 
3
- from typing import Optional, Type
4
-
5
3
  from pydantic import BaseModel, Field
6
4
 
7
5
  from intentkit.skills.defillama.api import fetch_block
@@ -34,9 +32,9 @@ class FetchBlockResponse(BaseModel):
34
32
  """Response schema for block data."""
35
33
 
36
34
  chain: str = Field(..., description="Normalized chain name")
37
- height: Optional[int] = Field(None, description="Block height number")
38
- timestamp: Optional[int] = Field(None, description="Unix timestamp of the block")
39
- error: Optional[str] = Field(None, description="Error message if any")
35
+ height: int | None = Field(None, description="Block height number")
36
+ timestamp: int | None = Field(None, description="Unix timestamp of the block")
37
+ error: str | None = Field(None, description="Error message if any")
40
38
 
41
39
 
42
40
  class DefiLlamaFetchBlock(DefiLlamaBaseTool):
@@ -55,7 +53,7 @@ class DefiLlamaFetchBlock(DefiLlamaBaseTool):
55
53
 
56
54
  name: str = "defillama_fetch_block"
57
55
  description: str = FETCH_BLOCK_PROMPT
58
- args_schema: Type[BaseModel] = FetchBlockInput
56
+ args_schema: type[BaseModel] = FetchBlockInput
59
57
 
60
58
  async def _arun(self, chain: str) -> FetchBlockResponse:
61
59
  """Fetch current block data for the given chain.
@@ -1,7 +1,5 @@
1
1
  """Tool for fetching token prices via DeFi Llama API."""
2
2
 
3
- from typing import Dict, List, Optional, Type
4
-
5
3
  from pydantic import BaseModel, Field
6
4
 
7
5
  from intentkit.skills.defillama.api import fetch_current_prices
@@ -29,13 +27,13 @@ class TokenPrice(BaseModel):
29
27
  symbol: str = Field(..., description="Token symbol")
30
28
  timestamp: int = Field(..., description="Unix timestamp of last price update")
31
29
  confidence: float = Field(..., description="Confidence score for the price data")
32
- decimals: Optional[int] = Field(None, description="Token decimals, if available")
30
+ decimals: int | None = Field(None, description="Token decimals, if available")
33
31
 
34
32
 
35
33
  class FetchCurrentPricesInput(BaseModel):
36
34
  """Input schema for fetching current token prices with a 4-hour search window."""
37
35
 
38
- coins: List[str] = Field(
36
+ coins: list[str] = Field(
39
37
  ...,
40
38
  description="List of token identifiers (e.g. 'ethereum:0x...', 'coingecko:ethereum')",
41
39
  )
@@ -44,10 +42,10 @@ class FetchCurrentPricesInput(BaseModel):
44
42
  class FetchCurrentPricesResponse(BaseModel):
45
43
  """Response schema for current token prices."""
46
44
 
47
- coins: Dict[str, TokenPrice] = Field(
45
+ coins: dict[str, TokenPrice] = Field(
48
46
  default_factory=dict, description="Token prices keyed by token identifier"
49
47
  )
50
- error: Optional[str] = Field(None, description="Error message if any")
48
+ error: str | None = Field(None, description="Error message if any")
51
49
 
52
50
 
53
51
  class DefiLlamaFetchCurrentPrices(DefiLlamaBaseTool):
@@ -69,9 +67,9 @@ class DefiLlamaFetchCurrentPrices(DefiLlamaBaseTool):
69
67
 
70
68
  name: str = "defillama_fetch_current_prices"
71
69
  description: str = FETCH_PRICES_PROMPT
72
- args_schema: Type[BaseModel] = FetchCurrentPricesInput
70
+ args_schema: type[BaseModel] = FetchCurrentPricesInput
73
71
 
74
- async def _arun(self, coins: List[str]) -> FetchCurrentPricesResponse:
72
+ async def _arun(self, coins: list[str]) -> FetchCurrentPricesResponse:
75
73
  """Fetch current prices for the given tokens.
76
74
 
77
75
  Args:
@@ -1,7 +1,5 @@
1
1
  """Tool for fetching first recorded token prices via DeFi Llama API."""
2
2
 
3
- from typing import Dict, List, Optional, Type
4
-
5
3
  from pydantic import BaseModel, Field
6
4
 
7
5
  from intentkit.skills.defillama.api import fetch_first_price
@@ -31,7 +29,7 @@ class FirstPriceData(BaseModel):
31
29
  class FetchFirstPriceInput(BaseModel):
32
30
  """Input schema for fetching first token prices."""
33
31
 
34
- coins: List[str] = Field(
32
+ coins: list[str] = Field(
35
33
  ..., description="List of token identifiers to fetch first prices for"
36
34
  )
37
35
 
@@ -39,10 +37,10 @@ class FetchFirstPriceInput(BaseModel):
39
37
  class FetchFirstPriceResponse(BaseModel):
40
38
  """Response schema for first token prices."""
41
39
 
42
- coins: Dict[str, FirstPriceData] = Field(
40
+ coins: dict[str, FirstPriceData] = Field(
43
41
  default_factory=dict, description="First price data keyed by token identifier"
44
42
  )
45
- error: Optional[str] = Field(None, description="Error message if any")
43
+ error: str | None = Field(None, description="Error message if any")
46
44
 
47
45
 
48
46
  class DefiLlamaFetchFirstPrice(DefiLlamaBaseTool):
@@ -64,9 +62,9 @@ class DefiLlamaFetchFirstPrice(DefiLlamaBaseTool):
64
62
 
65
63
  name: str = "defillama_fetch_first_price"
66
64
  description: str = FETCH_FIRST_PRICE_PROMPT
67
- args_schema: Type[BaseModel] = FetchFirstPriceInput
65
+ args_schema: type[BaseModel] = FetchFirstPriceInput
68
66
 
69
- async def _arun(self, coins: List[str]) -> FetchFirstPriceResponse:
67
+ async def _arun(self, coins: list[str]) -> FetchFirstPriceResponse:
70
68
  """Fetch first recorded prices for the given tokens.
71
69
 
72
70
  Args:
@@ -1,7 +1,5 @@
1
1
  """Tool for fetching historical token prices via DeFi Llama API."""
2
2
 
3
- from typing import Dict, List, Optional, Type
4
-
5
3
  from pydantic import BaseModel, Field
6
4
 
7
5
  from intentkit.skills.defillama.api import fetch_historical_prices
@@ -26,9 +24,9 @@ class HistoricalTokenPrice(BaseModel):
26
24
  """Model representing historical token price data."""
27
25
 
28
26
  price: float = Field(..., description="Token price in USD at the specified time")
29
- symbol: Optional[str] = Field(None, description="Token symbol")
27
+ symbol: str | None = Field(None, description="Token symbol")
30
28
  timestamp: int = Field(..., description="Unix timestamp of the price data")
31
- decimals: Optional[int] = Field(None, description="Token decimals, if available")
29
+ decimals: int | None = Field(None, description="Token decimals, if available")
32
30
 
33
31
 
34
32
  class FetchHistoricalPricesInput(BaseModel):
@@ -37,7 +35,7 @@ class FetchHistoricalPricesInput(BaseModel):
37
35
  timestamp: int = Field(
38
36
  ..., description="Unix timestamp for historical price lookup"
39
37
  )
40
- coins: List[str] = Field(
38
+ coins: list[str] = Field(
41
39
  ...,
42
40
  description="List of token identifiers (e.g. 'ethereum:0x...', 'coingecko:ethereum')",
43
41
  )
@@ -46,11 +44,11 @@ class FetchHistoricalPricesInput(BaseModel):
46
44
  class FetchHistoricalPricesResponse(BaseModel):
47
45
  """Response schema for historical token prices."""
48
46
 
49
- coins: Dict[str, HistoricalTokenPrice] = Field(
47
+ coins: dict[str, HistoricalTokenPrice] = Field(
50
48
  default_factory=dict,
51
49
  description="Historical token prices keyed by token identifier",
52
50
  )
53
- error: Optional[str] = Field(None, description="Error message if any")
51
+ error: str | None = Field(None, description="Error message if any")
54
52
 
55
53
 
56
54
  class DefiLlamaFetchHistoricalPrices(DefiLlamaBaseTool):
@@ -73,10 +71,10 @@ class DefiLlamaFetchHistoricalPrices(DefiLlamaBaseTool):
73
71
 
74
72
  name: str = "defillama_fetch_historical_prices"
75
73
  description: str = FETCH_HISTORICAL_PRICES_PROMPT
76
- args_schema: Type[BaseModel] = FetchHistoricalPricesInput
74
+ args_schema: type[BaseModel] = FetchHistoricalPricesInput
77
75
 
78
76
  async def _arun(
79
- self, timestamp: int, coins: List[str]
77
+ self, timestamp: int, coins: list[str]
80
78
  ) -> FetchHistoricalPricesResponse:
81
79
  """Fetch historical prices for the given tokens at the specified time.
82
80
 
@@ -1,7 +1,5 @@
1
1
  """Tool for fetching token price charts via DeFi Llama API."""
2
2
 
3
- from typing import Dict, List, Optional, Type
4
-
5
3
  from pydantic import BaseModel, Field
6
4
 
7
5
  from intentkit.skills.defillama.api import fetch_price_chart
@@ -33,14 +31,14 @@ class TokenPriceChart(BaseModel):
33
31
 
34
32
  symbol: str = Field(..., description="Token symbol")
35
33
  confidence: float = Field(..., description="Confidence score for the price data")
36
- decimals: Optional[int] = Field(None, description="Token decimals")
37
- prices: List[PricePoint] = Field(..., description="List of historical price points")
34
+ decimals: int | None = Field(None, description="Token decimals")
35
+ prices: list[PricePoint] = Field(..., description="List of historical price points")
38
36
 
39
37
 
40
38
  class FetchPriceChartInput(BaseModel):
41
39
  """Input schema for fetching token price charts."""
42
40
 
43
- coins: List[str] = Field(
41
+ coins: list[str] = Field(
44
42
  ..., description="List of token identifiers to fetch price charts for"
45
43
  )
46
44
 
@@ -48,10 +46,10 @@ class FetchPriceChartInput(BaseModel):
48
46
  class FetchPriceChartResponse(BaseModel):
49
47
  """Response schema for token price charts."""
50
48
 
51
- coins: Dict[str, TokenPriceChart] = Field(
49
+ coins: dict[str, TokenPriceChart] = Field(
52
50
  default_factory=dict, description="Price chart data keyed by token identifier"
53
51
  )
54
- error: Optional[str] = Field(None, description="Error message if any")
52
+ error: str | None = Field(None, description="Error message if any")
55
53
 
56
54
 
57
55
  class DefiLlamaFetchPriceChart(DefiLlamaBaseTool):
@@ -73,9 +71,9 @@ class DefiLlamaFetchPriceChart(DefiLlamaBaseTool):
73
71
 
74
72
  name: str = "defillama_fetch_price_chart"
75
73
  description: str = FETCH_PRICE_CHART_PROMPT
76
- args_schema: Type[BaseModel] = FetchPriceChartInput
74
+ args_schema: type[BaseModel] = FetchPriceChartInput
77
75
 
78
- async def _arun(self, coins: List[str]) -> FetchPriceChartResponse:
76
+ async def _arun(self, coins: list[str]) -> FetchPriceChartResponse:
79
77
  """Fetch price charts for the given tokens.
80
78
 
81
79
  Args:
@@ -1,7 +1,5 @@
1
1
  """Tool for fetching token price percentage changes via DeFi Llama API."""
2
2
 
3
- from typing import Dict, List, Optional, Type
4
-
5
3
  from pydantic import BaseModel, Field
6
4
 
7
5
  from intentkit.skills.defillama.api import fetch_price_percentage
@@ -23,7 +21,7 @@ Returns price percentage changes:
23
21
  class FetchPricePercentageInput(BaseModel):
24
22
  """Input schema for fetching token price percentage changes."""
25
23
 
26
- coins: List[str] = Field(
24
+ coins: list[str] = Field(
27
25
  ..., description="List of token identifiers to fetch price changes for"
28
26
  )
29
27
 
@@ -31,11 +29,11 @@ class FetchPricePercentageInput(BaseModel):
31
29
  class FetchPricePercentageResponse(BaseModel):
32
30
  """Response schema for token price percentage changes."""
33
31
 
34
- coins: Dict[str, float] = Field(
32
+ coins: dict[str, float] = Field(
35
33
  default_factory=dict,
36
34
  description="Price percentage changes keyed by token identifier",
37
35
  )
38
- error: Optional[str] = Field(None, description="Error message if any")
36
+ error: str | None = Field(None, description="Error message if any")
39
37
 
40
38
 
41
39
  class DefiLlamaFetchPricePercentage(DefiLlamaBaseTool):
@@ -57,9 +55,9 @@ class DefiLlamaFetchPricePercentage(DefiLlamaBaseTool):
57
55
 
58
56
  name: str = "defillama_fetch_price_percentage"
59
57
  description: str = FETCH_PRICE_PERCENTAGE_PROMPT
60
- args_schema: Type[BaseModel] = FetchPricePercentageInput
58
+ args_schema: type[BaseModel] = FetchPricePercentageInput
61
59
 
62
- async def _arun(self, coins: List[str]) -> FetchPricePercentageResponse:
60
+ async def _arun(self, coins: list[str]) -> FetchPricePercentageResponse:
63
61
  """Fetch price percentage changes for the given tokens.
64
62
 
65
63
  Args:
@@ -4,10 +4,8 @@ This module contains the valid chains and their aliases for use with the DeFi Ll
4
4
  The VALID_CHAINS dictionary maps primary chain identifiers to their known aliases.
5
5
  """
6
6
 
7
- from typing import Dict, List
8
-
9
7
  # Chain configuration with aliases
10
- VALID_CHAINS: Dict[str, List[str]] = {
8
+ VALID_CHAINS: dict[str, list[str]] = {
11
9
  "ethereum": ["eth", "eth1", "eth2"],
12
10
  "solana": ["sol"],
13
11
  "bitcoin": ["btc"],
@@ -1,7 +1,5 @@
1
1
  """Tool for fetching fees overview data via DeFi Llama API."""
2
2
 
3
- from typing import Dict, List, Optional, Type
4
-
5
3
  from pydantic import BaseModel, Field
6
4
 
7
5
  from intentkit.skills.defillama.api import fetch_fees_overview
@@ -20,16 +18,16 @@ Returns detailed metrics including:
20
18
  class ProtocolMethodology(BaseModel):
21
19
  """Model representing protocol methodology data."""
22
20
 
23
- UserFees: Optional[str] = Field(None, description="Description of user fees")
24
- Fees: Optional[str] = Field(None, description="Description of fees")
25
- Revenue: Optional[str] = Field(None, description="Description of revenue")
26
- ProtocolRevenue: Optional[str] = Field(
21
+ UserFees: str | None = Field(None, description="Description of user fees")
22
+ Fees: str | None = Field(None, description="Description of fees")
23
+ Revenue: str | None = Field(None, description="Description of revenue")
24
+ ProtocolRevenue: str | None = Field(
27
25
  None, description="Description of protocol revenue"
28
26
  )
29
- HoldersRevenue: Optional[str] = Field(
27
+ HoldersRevenue: str | None = Field(
30
28
  None, description="Description of holders revenue"
31
29
  )
32
- SupplySideRevenue: Optional[str] = Field(
30
+ SupplySideRevenue: str | None = Field(
33
31
  None, description="Description of supply side revenue"
34
32
  )
35
33
 
@@ -41,23 +39,23 @@ class Protocol(BaseModel):
41
39
  displayName: str = Field(..., description="Display name of protocol")
42
40
  category: str = Field(..., description="Protocol category")
43
41
  logo: str = Field(..., description="Logo URL")
44
- chains: List[str] = Field(..., description="Supported chains")
42
+ chains: list[str] = Field(..., description="Supported chains")
45
43
  module: str = Field(..., description="Protocol module")
46
- total24h: Optional[float] = Field(None, description="24-hour total fees")
47
- total7d: Optional[float] = Field(None, description="7-day total fees")
48
- total30d: Optional[float] = Field(None, description="30-day total fees")
49
- total1y: Optional[float] = Field(None, description="1-year total fees")
50
- totalAllTime: Optional[float] = Field(None, description="All-time total fees")
51
- change_1d: Optional[float] = Field(None, description="24-hour change percentage")
52
- change_7d: Optional[float] = Field(None, description="7-day change percentage")
53
- change_1m: Optional[float] = Field(None, description="30-day change percentage")
54
- methodology: Optional[ProtocolMethodology] = Field(
44
+ total24h: float | None = Field(None, description="24-hour total fees")
45
+ total7d: float | None = Field(None, description="7-day total fees")
46
+ total30d: float | None = Field(None, description="30-day total fees")
47
+ total1y: float | None = Field(None, description="1-year total fees")
48
+ totalAllTime: float | None = Field(None, description="All-time total fees")
49
+ change_1d: float | None = Field(None, description="24-hour change percentage")
50
+ change_7d: float | None = Field(None, description="7-day change percentage")
51
+ change_1m: float | None = Field(None, description="30-day change percentage")
52
+ methodology: ProtocolMethodology | None = Field(
55
53
  None, description="Protocol methodology"
56
54
  )
57
- breakdown24h: Optional[Dict[str, Dict[str, float]]] = Field(
55
+ breakdown24h: dict[str, dict[str, float]] | None = Field(
58
56
  None, description="24-hour breakdown by chain"
59
57
  )
60
- breakdown30d: Optional[Dict[str, Dict[str, float]]] = Field(
58
+ breakdown30d: dict[str, dict[str, float]] | None = Field(
61
59
  None, description="30-day breakdown by chain"
62
60
  )
63
61
 
@@ -72,9 +70,9 @@ class FetchFeesOverviewResponse(BaseModel):
72
70
  change_1d: float = Field(..., description="24-hour change percentage")
73
71
  change_7d: float = Field(..., description="7-day change percentage")
74
72
  change_1m: float = Field(..., description="30-day change percentage")
75
- allChains: List[str] = Field(..., description="List of all chains")
76
- protocols: List[Protocol] = Field(..., description="List of protocols")
77
- error: Optional[str] = Field(None, description="Error message if any")
73
+ allChains: list[str] = Field(..., description="List of all chains")
74
+ protocols: list[Protocol] = Field(..., description="List of protocols")
75
+ error: str | None = Field(None, description="Error message if any")
78
76
 
79
77
 
80
78
  class DefiLlamaFetchFeesOverview(DefiLlamaBaseTool):
@@ -100,7 +98,7 @@ class DefiLlamaFetchFeesOverview(DefiLlamaBaseTool):
100
98
 
101
99
  pass
102
100
 
103
- args_schema: Type[BaseModel] = EmptyArgsSchema
101
+ args_schema: type[BaseModel] = EmptyArgsSchema
104
102
 
105
103
  async def _arun(self, **kwargs) -> FetchFeesOverviewResponse:
106
104
  """Fetch overview data for protocol fees.
@@ -1,7 +1,5 @@
1
1
  """Tool for fetching stablecoin chains data via DeFi Llama API."""
2
2
 
3
- from typing import List, Optional
4
-
5
3
  from pydantic import BaseModel, Field
6
4
 
7
5
  from intentkit.skills.defillama.api import fetch_stablecoin_chains
@@ -19,16 +17,16 @@ Returns:
19
17
  class CirculatingUSD(BaseModel):
20
18
  """Model representing circulating amounts in different pegs."""
21
19
 
22
- peggedUSD: Optional[float] = Field(None, description="Amount pegged to USD")
23
- peggedEUR: Optional[float] = Field(None, description="Amount pegged to EUR")
24
- peggedVAR: Optional[float] = Field(None, description="Amount in variable pegs")
25
- peggedJPY: Optional[float] = Field(None, description="Amount pegged to JPY")
26
- peggedCHF: Optional[float] = Field(None, description="Amount pegged to CHF")
27
- peggedCAD: Optional[float] = Field(None, description="Amount pegged to CAD")
28
- peggedGBP: Optional[float] = Field(None, description="Amount pegged to GBP")
29
- peggedAUD: Optional[float] = Field(None, description="Amount pegged to AUD")
30
- peggedCNY: Optional[float] = Field(None, description="Amount pegged to CNY")
31
- peggedREAL: Optional[float] = Field(
20
+ peggedUSD: float | None = Field(None, description="Amount pegged to USD")
21
+ peggedEUR: float | None = Field(None, description="Amount pegged to EUR")
22
+ peggedVAR: float | None = Field(None, description="Amount in variable pegs")
23
+ peggedJPY: float | None = Field(None, description="Amount pegged to JPY")
24
+ peggedCHF: float | None = Field(None, description="Amount pegged to CHF")
25
+ peggedCAD: float | None = Field(None, description="Amount pegged to CAD")
26
+ peggedGBP: float | None = Field(None, description="Amount pegged to GBP")
27
+ peggedAUD: float | None = Field(None, description="Amount pegged to AUD")
28
+ peggedCNY: float | None = Field(None, description="Amount pegged to CNY")
29
+ peggedREAL: float | None = Field(
32
30
  None, description="Amount pegged to Brazilian Real"
33
31
  )
34
32
 
@@ -36,21 +34,21 @@ class CirculatingUSD(BaseModel):
36
34
  class ChainData(BaseModel):
37
35
  """Model representing stablecoin data for a single chain."""
38
36
 
39
- gecko_id: Optional[str] = Field(None, description="CoinGecko ID of the chain")
37
+ gecko_id: str | None = Field(None, description="CoinGecko ID of the chain")
40
38
  totalCirculatingUSD: CirculatingUSD = Field(
41
39
  ..., description="Total circulating amounts in different pegs"
42
40
  )
43
- tokenSymbol: Optional[str] = Field(None, description="Native token symbol")
41
+ tokenSymbol: str | None = Field(None, description="Native token symbol")
44
42
  name: str = Field(..., description="Chain name")
45
43
 
46
44
 
47
45
  class FetchStablecoinChainsResponse(BaseModel):
48
46
  """Response schema for stablecoin chains data."""
49
47
 
50
- chains: List[ChainData] = Field(
48
+ chains: list[ChainData] = Field(
51
49
  default_factory=list, description="List of chains with their stablecoin data"
52
50
  )
53
- error: Optional[str] = Field(None, description="Error message if any")
51
+ error: str | None = Field(None, description="Error message if any")
54
52
 
55
53
 
56
54
  class DefiLlamaFetchStablecoinChains(DefiLlamaBaseTool):
@@ -1,7 +1,5 @@
1
1
  """Tool for fetching stablecoin charts via DeFi Llama API."""
2
2
 
3
- from typing import List, Optional, Type
4
-
5
3
  from pydantic import BaseModel, Field
6
4
 
7
5
  from intentkit.skills.defillama.api import fetch_stablecoin_charts
@@ -44,7 +42,7 @@ class FetchStablecoinChartsInput(BaseModel):
44
42
  stablecoin_id: str = Field(
45
43
  ..., description="ID of the stablecoin to fetch data for"
46
44
  )
47
- chain: Optional[str] = Field(
45
+ chain: str | None = Field(
48
46
  None, description="Optional chain name for chain-specific data"
49
47
  )
50
48
 
@@ -52,13 +50,13 @@ class FetchStablecoinChartsInput(BaseModel):
52
50
  class FetchStablecoinChartsResponse(BaseModel):
53
51
  """Response schema for stablecoin chart data."""
54
52
 
55
- data: List[StablecoinDataPoint] = Field(
53
+ data: list[StablecoinDataPoint] = Field(
56
54
  default_factory=list, description="List of historical data points"
57
55
  )
58
- chain: Optional[str] = Field(
56
+ chain: str | None = Field(
59
57
  None, description="Chain name if chain-specific data was requested"
60
58
  )
61
- error: Optional[str] = Field(None, description="Error message if any")
59
+ error: str | None = Field(None, description="Error message if any")
62
60
 
63
61
 
64
62
  class DefiLlamaFetchStablecoinCharts(DefiLlamaBaseTool):
@@ -81,10 +79,10 @@ class DefiLlamaFetchStablecoinCharts(DefiLlamaBaseTool):
81
79
 
82
80
  name: str = "defillama_fetch_stablecoin_charts"
83
81
  description: str = FETCH_STABLECOIN_CHARTS_PROMPT
84
- args_schema: Type[BaseModel] = FetchStablecoinChartsInput
82
+ args_schema: type[BaseModel] = FetchStablecoinChartsInput
85
83
 
86
84
  async def _arun(
87
- self, stablecoin_id: str, chain: Optional[str] = None
85
+ self, stablecoin_id: str, chain: str | None = None
88
86
  ) -> FetchStablecoinChartsResponse:
89
87
  """Fetch historical chart data for the given stablecoin.
90
88
 
@@ -1,7 +1,5 @@
1
1
  """Tool for fetching stablecoin prices via DeFi Llama API."""
2
2
 
3
- from typing import Dict, List, Optional
4
-
5
3
  from pydantic import BaseModel, Field
6
4
 
7
5
  from intentkit.skills.defillama.api import fetch_stablecoin_prices
@@ -20,7 +18,7 @@ class PriceDataPoint(BaseModel):
20
18
  """Model representing a price data point."""
21
19
 
22
20
  date: str = Field(..., description="Unix timestamp for the price data")
23
- prices: Dict[str, float] = Field(
21
+ prices: dict[str, float] = Field(
24
22
  ..., description="Dictionary of stablecoin prices indexed by identifier"
25
23
  )
26
24
 
@@ -28,10 +26,10 @@ class PriceDataPoint(BaseModel):
28
26
  class FetchStablecoinPricesResponse(BaseModel):
29
27
  """Response schema for stablecoin prices data."""
30
28
 
31
- data: List[PriceDataPoint] = Field(
29
+ data: list[PriceDataPoint] = Field(
32
30
  default_factory=list, description="List of price data points"
33
31
  )
34
- error: Optional[str] = Field(None, description="Error message if any")
32
+ error: str | None = Field(None, description="Error message if any")
35
33
 
36
34
 
37
35
  class DefiLlamaFetchStablecoinPrices(DefiLlamaBaseTool):
@@ -1,7 +1,5 @@
1
1
  """Tool for fetching stablecoin data via DeFi Llama API."""
2
2
 
3
- from typing import Dict, List, Optional
4
-
5
3
  from pydantic import BaseModel, Field
6
4
 
7
5
  from intentkit.skills.defillama.api import fetch_stablecoins
@@ -45,7 +43,7 @@ class Stablecoin(BaseModel):
45
43
  id: str = Field(..., description="Unique identifier")
46
44
  name: str = Field(..., description="Stablecoin name")
47
45
  symbol: str = Field(..., description="Token symbol")
48
- gecko_id: Optional[str] = Field(None, description="CoinGecko ID if available")
46
+ gecko_id: str | None = Field(None, description="CoinGecko ID if available")
49
47
  pegType: str = Field(..., description="Type of peg (e.g. peggedUSD)")
50
48
  priceSource: str = Field(..., description="Source of price data")
51
49
  pegMechanism: str = Field(..., description="Mechanism maintaining the peg")
@@ -61,10 +59,10 @@ class Stablecoin(BaseModel):
61
59
  circulatingPrevMonth: CirculatingAmount = Field(
62
60
  ..., description="Total circulating amount from previous month"
63
61
  )
64
- chainCirculating: Dict[str, ChainCirculating] = Field(
62
+ chainCirculating: dict[str, ChainCirculating] = Field(
65
63
  ..., description="Circulating amounts per chain"
66
64
  )
67
- chains: List[str] = Field(
65
+ chains: list[str] = Field(
68
66
  ..., description="List of chains where the stablecoin is present"
69
67
  )
70
68
  price: float = Field(..., description="Current price in USD")
@@ -73,10 +71,10 @@ class Stablecoin(BaseModel):
73
71
  class FetchStablecoinsResponse(BaseModel):
74
72
  """Response schema for stablecoin data."""
75
73
 
76
- peggedAssets: List[Stablecoin] = Field(
74
+ peggedAssets: list[Stablecoin] = Field(
77
75
  default_factory=list, description="List of stablecoins with their data"
78
76
  )
79
- error: Optional[str] = Field(None, description="Error message if any")
77
+ error: str | None = Field(None, description="Error message if any")
80
78
 
81
79
 
82
80
  class DefiLlamaFetchStablecoins(DefiLlamaBaseTool):
@@ -84,7 +84,7 @@ class TestDefiLlamaAPI(unittest.TestCase):
84
84
  return self.loop.run_until_complete(
85
85
  asyncio.wait_for(coro, timeout=self.timeout)
86
86
  )
87
- except asyncio.TimeoutError:
87
+ except TimeoutError:
88
88
  raise AssertionError(f"Test timed out after {self.timeout} seconds")
89
89
  except Exception as e:
90
90
  raise AssertionError(f"Test failed with exception: {str(e)}")
@@ -1,7 +1,5 @@
1
1
  """Tool for fetching chain historical TVL via DeFiLlama API."""
2
2
 
3
- from typing import List, Type
4
-
5
3
  from pydantic import BaseModel, Field
6
4
 
7
5
  from intentkit.skills.defillama.api import fetch_chain_historical_tvl
@@ -33,7 +31,7 @@ class FetchChainHistoricalTVLResponse(BaseModel):
33
31
  """Response schema for chain-specific historical TVL data."""
34
32
 
35
33
  chain: str = Field(..., description="Normalized chain name")
36
- data: List[HistoricalTVLDataPoint] = Field(
34
+ data: list[HistoricalTVLDataPoint] = Field(
37
35
  default_factory=list, description="List of historical TVL data points"
38
36
  )
39
37
  error: str | None = Field(default=None, description="Error message if any")
@@ -57,7 +55,7 @@ class DefiLlamaFetchChainHistoricalTvl(DefiLlamaBaseTool):
57
55
 
58
56
  name: str = "defillama_fetch_chain_historical_tvl"
59
57
  description: str = FETCH_HISTORICAL_TVL_PROMPT
60
- args_schema: Type[BaseModel] = FetchChainHistoricalTVLInput
58
+ args_schema: type[BaseModel] = FetchChainHistoricalTVLInput
61
59
 
62
60
  async def _arun(self, chain: str) -> FetchChainHistoricalTVLResponse:
63
61
  """Fetch historical TVL data for the given chain.