intentkit 0.6.13.dev2__py3-none-any.whl → 0.8.17__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 (385) 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 +14 -7
  5. intentkit/abstracts/skill.py +6 -144
  6. intentkit/abstracts/twitter.py +4 -5
  7. intentkit/clients/__init__.py +5 -2
  8. intentkit/clients/cdp.py +101 -141
  9. intentkit/clients/twitter.py +83 -62
  10. intentkit/clients/web3.py +29 -0
  11. intentkit/config/config.py +8 -5
  12. intentkit/core/agent.py +472 -195
  13. intentkit/core/asset.py +253 -0
  14. intentkit/core/chat.py +51 -0
  15. intentkit/core/client.py +1 -1
  16. intentkit/core/credit.py +460 -130
  17. intentkit/core/engine.py +262 -233
  18. intentkit/core/node.py +15 -16
  19. intentkit/core/prompt.py +62 -28
  20. intentkit/core/scheduler.py +92 -0
  21. intentkit/core/statistics.py +168 -0
  22. intentkit/models/agent.py +1096 -949
  23. intentkit/models/agent_data.py +68 -38
  24. intentkit/models/agent_public.json +98 -0
  25. intentkit/models/agent_schema.json +54 -439
  26. intentkit/models/app_setting.py +96 -33
  27. intentkit/models/chat.py +74 -27
  28. intentkit/models/conversation.py +8 -8
  29. intentkit/models/credit.py +362 -74
  30. intentkit/models/db.py +26 -8
  31. intentkit/models/db_mig.py +2 -2
  32. intentkit/models/llm.csv +28 -0
  33. intentkit/models/llm.py +185 -350
  34. intentkit/models/redis.py +6 -4
  35. intentkit/models/skill.py +186 -72
  36. intentkit/models/skills.csv +174 -0
  37. intentkit/models/user.py +82 -24
  38. intentkit/skills/acolyt/__init__.py +2 -9
  39. intentkit/skills/acolyt/ask.py +3 -4
  40. intentkit/skills/acolyt/base.py +4 -9
  41. intentkit/skills/acolyt/schema.json +4 -3
  42. intentkit/skills/aixbt/__init__.py +2 -13
  43. intentkit/skills/aixbt/base.py +1 -7
  44. intentkit/skills/aixbt/projects.py +14 -15
  45. intentkit/skills/aixbt/schema.json +4 -4
  46. intentkit/skills/allora/__init__.py +2 -9
  47. intentkit/skills/allora/base.py +4 -9
  48. intentkit/skills/allora/price.py +3 -4
  49. intentkit/skills/allora/schema.json +3 -2
  50. intentkit/skills/base.py +248 -85
  51. intentkit/skills/basename/__init__.py +51 -0
  52. intentkit/skills/basename/base.py +11 -0
  53. intentkit/skills/basename/basename.svg +11 -0
  54. intentkit/skills/basename/schema.json +58 -0
  55. intentkit/skills/carv/__init__.py +115 -121
  56. intentkit/skills/carv/base.py +184 -185
  57. intentkit/skills/carv/fetch_news.py +3 -3
  58. intentkit/skills/carv/onchain_query.py +4 -4
  59. intentkit/skills/carv/schema.json +134 -137
  60. intentkit/skills/carv/token_info_and_price.py +5 -5
  61. intentkit/skills/casino/README.md +254 -0
  62. intentkit/skills/casino/__init__.py +86 -0
  63. intentkit/skills/casino/base.py +17 -0
  64. intentkit/skills/casino/casino.png +0 -0
  65. intentkit/skills/casino/deck_draw.py +127 -0
  66. intentkit/skills/casino/deck_shuffle.py +118 -0
  67. intentkit/skills/casino/dice_roll.py +100 -0
  68. intentkit/skills/casino/schema.json +77 -0
  69. intentkit/skills/casino/utils.py +107 -0
  70. intentkit/skills/cdp/__init__.py +22 -84
  71. intentkit/skills/cdp/base.py +1 -7
  72. intentkit/skills/cdp/schema.json +11 -314
  73. intentkit/skills/chainlist/__init__.py +2 -7
  74. intentkit/skills/chainlist/base.py +1 -7
  75. intentkit/skills/chainlist/chain_lookup.py +18 -18
  76. intentkit/skills/chainlist/schema.json +3 -5
  77. intentkit/skills/common/__init__.py +2 -9
  78. intentkit/skills/common/base.py +1 -7
  79. intentkit/skills/common/current_time.py +1 -2
  80. intentkit/skills/common/schema.json +2 -2
  81. intentkit/skills/cookiefun/__init__.py +6 -9
  82. intentkit/skills/cookiefun/base.py +2 -7
  83. intentkit/skills/cookiefun/get_account_details.py +7 -7
  84. intentkit/skills/cookiefun/get_account_feed.py +19 -19
  85. intentkit/skills/cookiefun/get_account_smart_followers.py +7 -7
  86. intentkit/skills/cookiefun/get_sectors.py +3 -3
  87. intentkit/skills/cookiefun/schema.json +1 -3
  88. intentkit/skills/cookiefun/search_accounts.py +9 -9
  89. intentkit/skills/cryptocompare/__init__.py +7 -24
  90. intentkit/skills/cryptocompare/api.py +2 -3
  91. intentkit/skills/cryptocompare/base.py +11 -25
  92. intentkit/skills/cryptocompare/fetch_news.py +4 -5
  93. intentkit/skills/cryptocompare/fetch_price.py +6 -7
  94. intentkit/skills/cryptocompare/fetch_top_exchanges.py +4 -5
  95. intentkit/skills/cryptocompare/fetch_top_market_cap.py +4 -5
  96. intentkit/skills/cryptocompare/fetch_top_volume.py +4 -5
  97. intentkit/skills/cryptocompare/fetch_trading_signals.py +5 -6
  98. intentkit/skills/cryptocompare/schema.json +3 -3
  99. intentkit/skills/cryptopanic/__init__.py +7 -10
  100. intentkit/skills/cryptopanic/base.py +51 -55
  101. intentkit/skills/cryptopanic/fetch_crypto_news.py +4 -8
  102. intentkit/skills/cryptopanic/fetch_crypto_sentiment.py +5 -7
  103. intentkit/skills/cryptopanic/schema.json +105 -103
  104. intentkit/skills/dapplooker/__init__.py +2 -9
  105. intentkit/skills/dapplooker/base.py +4 -9
  106. intentkit/skills/dapplooker/dapplooker_token_data.py +7 -7
  107. intentkit/skills/dapplooker/schema.json +3 -5
  108. intentkit/skills/defillama/__init__.py +24 -74
  109. intentkit/skills/defillama/api.py +6 -9
  110. intentkit/skills/defillama/base.py +11 -21
  111. intentkit/skills/defillama/coins/fetch_batch_historical_prices.py +8 -10
  112. intentkit/skills/defillama/coins/fetch_block.py +6 -8
  113. intentkit/skills/defillama/coins/fetch_current_prices.py +8 -10
  114. intentkit/skills/defillama/coins/fetch_first_price.py +7 -9
  115. intentkit/skills/defillama/coins/fetch_historical_prices.py +9 -11
  116. intentkit/skills/defillama/coins/fetch_price_chart.py +9 -11
  117. intentkit/skills/defillama/coins/fetch_price_percentage.py +7 -9
  118. intentkit/skills/defillama/config/chains.py +1 -3
  119. intentkit/skills/defillama/fees/fetch_fees_overview.py +24 -26
  120. intentkit/skills/defillama/schema.json +5 -1
  121. intentkit/skills/defillama/stablecoins/fetch_stablecoin_chains.py +16 -18
  122. intentkit/skills/defillama/stablecoins/fetch_stablecoin_charts.py +8 -10
  123. intentkit/skills/defillama/stablecoins/fetch_stablecoin_prices.py +5 -7
  124. intentkit/skills/defillama/stablecoins/fetch_stablecoins.py +7 -9
  125. intentkit/skills/defillama/tests/api_integration.test.py +1 -1
  126. intentkit/skills/defillama/tvl/fetch_chain_historical_tvl.py +4 -6
  127. intentkit/skills/defillama/tvl/fetch_chains.py +9 -11
  128. intentkit/skills/defillama/tvl/fetch_historical_tvl.py +4 -6
  129. intentkit/skills/defillama/tvl/fetch_protocol.py +32 -38
  130. intentkit/skills/defillama/tvl/fetch_protocol_current_tvl.py +3 -5
  131. intentkit/skills/defillama/tvl/fetch_protocols.py +37 -45
  132. intentkit/skills/defillama/volumes/fetch_dex_overview.py +42 -48
  133. intentkit/skills/defillama/volumes/fetch_dex_summary.py +35 -37
  134. intentkit/skills/defillama/volumes/fetch_options_overview.py +24 -28
  135. intentkit/skills/defillama/yields/fetch_pool_chart.py +10 -12
  136. intentkit/skills/defillama/yields/fetch_pools.py +26 -30
  137. intentkit/skills/dexscreener/README.md +154 -0
  138. intentkit/skills/dexscreener/__init__.py +97 -93
  139. intentkit/skills/dexscreener/base.py +125 -133
  140. intentkit/skills/dexscreener/get_pair_info.py +158 -0
  141. intentkit/skills/dexscreener/get_token_pairs.py +165 -0
  142. intentkit/skills/dexscreener/get_tokens_info.py +212 -0
  143. intentkit/skills/dexscreener/model/search_token_response.py +80 -82
  144. intentkit/skills/dexscreener/schema.json +91 -48
  145. intentkit/skills/dexscreener/search_token.py +182 -321
  146. intentkit/skills/dexscreener/utils.py +420 -0
  147. intentkit/skills/dune_analytics/__init__.py +7 -9
  148. intentkit/skills/dune_analytics/base.py +48 -52
  149. intentkit/skills/dune_analytics/fetch_kol_buys.py +5 -7
  150. intentkit/skills/dune_analytics/fetch_nation_metrics.py +6 -8
  151. intentkit/skills/dune_analytics/schema.json +104 -99
  152. intentkit/skills/elfa/__init__.py +5 -18
  153. intentkit/skills/elfa/base.py +10 -14
  154. intentkit/skills/elfa/mention.py +19 -21
  155. intentkit/skills/elfa/schema.json +3 -2
  156. intentkit/skills/elfa/stats.py +4 -4
  157. intentkit/skills/elfa/tokens.py +12 -12
  158. intentkit/skills/elfa/utils.py +26 -28
  159. intentkit/skills/enso/__init__.py +11 -31
  160. intentkit/skills/enso/base.py +50 -35
  161. intentkit/skills/enso/best_yield.py +16 -24
  162. intentkit/skills/enso/networks.py +6 -11
  163. intentkit/skills/enso/prices.py +11 -13
  164. intentkit/skills/enso/route.py +34 -38
  165. intentkit/skills/enso/schema.json +3 -2
  166. intentkit/skills/enso/tokens.py +29 -38
  167. intentkit/skills/enso/wallet.py +76 -191
  168. intentkit/skills/erc20/__init__.py +50 -0
  169. intentkit/skills/erc20/base.py +11 -0
  170. intentkit/skills/erc20/erc20.svg +5 -0
  171. intentkit/skills/erc20/schema.json +74 -0
  172. intentkit/skills/erc721/__init__.py +53 -0
  173. intentkit/skills/erc721/base.py +11 -0
  174. intentkit/skills/erc721/erc721.svg +5 -0
  175. intentkit/skills/erc721/schema.json +90 -0
  176. intentkit/skills/firecrawl/README.md +11 -5
  177. intentkit/skills/firecrawl/__init__.py +5 -18
  178. intentkit/skills/firecrawl/base.py +4 -11
  179. intentkit/skills/firecrawl/clear.py +4 -8
  180. intentkit/skills/firecrawl/crawl.py +19 -19
  181. intentkit/skills/firecrawl/query.py +4 -3
  182. intentkit/skills/firecrawl/schema.json +6 -8
  183. intentkit/skills/firecrawl/scrape.py +150 -40
  184. intentkit/skills/firecrawl/utils.py +50 -42
  185. intentkit/skills/github/__init__.py +2 -7
  186. intentkit/skills/github/base.py +1 -7
  187. intentkit/skills/github/github_search.py +1 -2
  188. intentkit/skills/github/schema.json +3 -4
  189. intentkit/skills/heurist/__init__.py +8 -27
  190. intentkit/skills/heurist/base.py +4 -9
  191. intentkit/skills/heurist/image_generation_animagine_xl.py +12 -13
  192. intentkit/skills/heurist/image_generation_arthemy_comics.py +12 -13
  193. intentkit/skills/heurist/image_generation_arthemy_real.py +12 -13
  194. intentkit/skills/heurist/image_generation_braindance.py +12 -13
  195. intentkit/skills/heurist/image_generation_cyber_realistic_xl.py +12 -13
  196. intentkit/skills/heurist/image_generation_flux_1_dev.py +12 -13
  197. intentkit/skills/heurist/image_generation_sdxl.py +12 -13
  198. intentkit/skills/heurist/schema.json +2 -2
  199. intentkit/skills/http/__init__.py +4 -15
  200. intentkit/skills/http/base.py +1 -7
  201. intentkit/skills/http/get.py +21 -16
  202. intentkit/skills/http/post.py +23 -18
  203. intentkit/skills/http/put.py +23 -18
  204. intentkit/skills/http/schema.json +4 -5
  205. intentkit/skills/lifi/__init__.py +8 -13
  206. intentkit/skills/lifi/base.py +1 -7
  207. intentkit/skills/lifi/schema.json +17 -8
  208. intentkit/skills/lifi/token_execute.py +36 -30
  209. intentkit/skills/lifi/token_quote.py +8 -10
  210. intentkit/skills/lifi/utils.py +104 -51
  211. intentkit/skills/moralis/__init__.py +6 -10
  212. intentkit/skills/moralis/api.py +6 -7
  213. intentkit/skills/moralis/base.py +5 -10
  214. intentkit/skills/moralis/fetch_chain_portfolio.py +10 -11
  215. intentkit/skills/moralis/fetch_nft_portfolio.py +22 -22
  216. intentkit/skills/moralis/fetch_solana_portfolio.py +11 -12
  217. intentkit/skills/moralis/fetch_wallet_portfolio.py +8 -9
  218. intentkit/skills/moralis/schema.json +7 -2
  219. intentkit/skills/morpho/__init__.py +52 -0
  220. intentkit/skills/morpho/base.py +11 -0
  221. intentkit/skills/morpho/morpho.svg +12 -0
  222. intentkit/skills/morpho/schema.json +73 -0
  223. intentkit/skills/nation/__init__.py +4 -9
  224. intentkit/skills/nation/base.py +5 -10
  225. intentkit/skills/nation/nft_check.py +3 -4
  226. intentkit/skills/nation/schema.json +4 -3
  227. intentkit/skills/onchain.py +23 -0
  228. intentkit/skills/openai/__init__.py +17 -18
  229. intentkit/skills/openai/base.py +10 -14
  230. intentkit/skills/openai/dalle_image_generation.py +3 -8
  231. intentkit/skills/openai/gpt_avatar_generator.py +102 -0
  232. intentkit/skills/openai/gpt_image_generation.py +4 -8
  233. intentkit/skills/openai/gpt_image_mini_generator.py +91 -0
  234. intentkit/skills/openai/gpt_image_to_image.py +4 -8
  235. intentkit/skills/openai/image_to_text.py +3 -7
  236. intentkit/skills/openai/schema.json +34 -3
  237. intentkit/skills/portfolio/__init__.py +11 -35
  238. intentkit/skills/portfolio/base.py +33 -19
  239. intentkit/skills/portfolio/schema.json +3 -5
  240. intentkit/skills/portfolio/token_balances.py +21 -21
  241. intentkit/skills/portfolio/wallet_approvals.py +17 -18
  242. intentkit/skills/portfolio/wallet_defi_positions.py +3 -3
  243. intentkit/skills/portfolio/wallet_history.py +31 -31
  244. intentkit/skills/portfolio/wallet_net_worth.py +13 -13
  245. intentkit/skills/portfolio/wallet_nfts.py +19 -19
  246. intentkit/skills/portfolio/wallet_profitability.py +18 -18
  247. intentkit/skills/portfolio/wallet_profitability_summary.py +5 -5
  248. intentkit/skills/portfolio/wallet_stats.py +3 -3
  249. intentkit/skills/portfolio/wallet_swaps.py +19 -19
  250. intentkit/skills/pyth/__init__.py +50 -0
  251. intentkit/skills/pyth/base.py +11 -0
  252. intentkit/skills/pyth/pyth.svg +6 -0
  253. intentkit/skills/pyth/schema.json +75 -0
  254. intentkit/skills/skills.toml +40 -0
  255. intentkit/skills/slack/__init__.py +5 -17
  256. intentkit/skills/slack/base.py +3 -9
  257. intentkit/skills/slack/get_channel.py +8 -8
  258. intentkit/skills/slack/get_message.py +9 -9
  259. intentkit/skills/slack/schedule_message.py +5 -5
  260. intentkit/skills/slack/schema.json +2 -2
  261. intentkit/skills/slack/send_message.py +3 -5
  262. intentkit/skills/supabase/__init__.py +7 -23
  263. intentkit/skills/supabase/base.py +9 -13
  264. intentkit/skills/supabase/delete_data.py +5 -6
  265. intentkit/skills/supabase/fetch_data.py +13 -14
  266. intentkit/skills/supabase/insert_data.py +5 -6
  267. intentkit/skills/supabase/invoke_function.py +7 -8
  268. intentkit/skills/supabase/schema.json +2 -3
  269. intentkit/skills/supabase/update_data.py +7 -8
  270. intentkit/skills/supabase/upsert_data.py +5 -6
  271. intentkit/skills/superfluid/__init__.py +53 -0
  272. intentkit/skills/superfluid/base.py +11 -0
  273. intentkit/skills/superfluid/schema.json +89 -0
  274. intentkit/skills/superfluid/superfluid.svg +6 -0
  275. intentkit/skills/system/__init__.py +7 -24
  276. intentkit/skills/system/add_autonomous_task.py +10 -12
  277. intentkit/skills/system/delete_autonomous_task.py +2 -2
  278. intentkit/skills/system/edit_autonomous_task.py +14 -18
  279. intentkit/skills/system/list_autonomous_tasks.py +3 -5
  280. intentkit/skills/system/read_agent_api_key.py +6 -4
  281. intentkit/skills/system/regenerate_agent_api_key.py +6 -4
  282. intentkit/skills/system/schema.json +6 -8
  283. intentkit/skills/tavily/__init__.py +3 -12
  284. intentkit/skills/tavily/base.py +4 -9
  285. intentkit/skills/tavily/schema.json +3 -5
  286. intentkit/skills/tavily/tavily_extract.py +2 -4
  287. intentkit/skills/tavily/tavily_search.py +4 -6
  288. intentkit/skills/token/__init__.py +5 -10
  289. intentkit/skills/token/base.py +7 -11
  290. intentkit/skills/token/erc20_transfers.py +19 -19
  291. intentkit/skills/token/schema.json +3 -6
  292. intentkit/skills/token/token_analytics.py +3 -3
  293. intentkit/skills/token/token_price.py +13 -13
  294. intentkit/skills/token/token_search.py +9 -9
  295. intentkit/skills/twitter/__init__.py +11 -35
  296. intentkit/skills/twitter/base.py +23 -35
  297. intentkit/skills/twitter/follow_user.py +3 -7
  298. intentkit/skills/twitter/get_mentions.py +6 -13
  299. intentkit/skills/twitter/get_timeline.py +5 -13
  300. intentkit/skills/twitter/get_user_by_username.py +3 -7
  301. intentkit/skills/twitter/get_user_tweets.py +6 -14
  302. intentkit/skills/twitter/like_tweet.py +3 -7
  303. intentkit/skills/twitter/post_tweet.py +23 -12
  304. intentkit/skills/twitter/reply_tweet.py +21 -12
  305. intentkit/skills/twitter/retweet.py +3 -7
  306. intentkit/skills/twitter/schema.json +1 -0
  307. intentkit/skills/twitter/search_tweets.py +5 -13
  308. intentkit/skills/unrealspeech/__init__.py +2 -7
  309. intentkit/skills/unrealspeech/base.py +2 -8
  310. intentkit/skills/unrealspeech/schema.json +2 -5
  311. intentkit/skills/unrealspeech/text_to_speech.py +8 -8
  312. intentkit/skills/venice_audio/__init__.py +98 -106
  313. intentkit/skills/venice_audio/base.py +117 -121
  314. intentkit/skills/venice_audio/input.py +41 -41
  315. intentkit/skills/venice_audio/schema.json +151 -152
  316. intentkit/skills/venice_audio/venice_audio.py +38 -21
  317. intentkit/skills/venice_image/__init__.py +147 -154
  318. intentkit/skills/venice_image/api.py +138 -138
  319. intentkit/skills/venice_image/base.py +185 -192
  320. intentkit/skills/venice_image/config.py +33 -35
  321. intentkit/skills/venice_image/image_enhance/image_enhance.py +2 -3
  322. intentkit/skills/venice_image/image_enhance/image_enhance_base.py +21 -23
  323. intentkit/skills/venice_image/image_enhance/image_enhance_input.py +38 -40
  324. intentkit/skills/venice_image/image_generation/image_generation_base.py +9 -9
  325. intentkit/skills/venice_image/image_generation/image_generation_fluently_xl.py +26 -26
  326. intentkit/skills/venice_image/image_generation/image_generation_flux_dev.py +27 -27
  327. intentkit/skills/venice_image/image_generation/image_generation_flux_dev_uncensored.py +26 -26
  328. intentkit/skills/venice_image/image_generation/image_generation_input.py +158 -158
  329. intentkit/skills/venice_image/image_generation/image_generation_lustify_sdxl.py +26 -26
  330. intentkit/skills/venice_image/image_generation/image_generation_pony_realism.py +26 -26
  331. intentkit/skills/venice_image/image_generation/image_generation_stable_diffusion_3_5.py +28 -28
  332. intentkit/skills/venice_image/image_generation/image_generation_venice_sd35.py +28 -28
  333. intentkit/skills/venice_image/image_upscale/image_upscale.py +3 -3
  334. intentkit/skills/venice_image/image_upscale/image_upscale_base.py +21 -23
  335. intentkit/skills/venice_image/image_upscale/image_upscale_input.py +22 -22
  336. intentkit/skills/venice_image/image_vision/image_vision.py +2 -2
  337. intentkit/skills/venice_image/image_vision/image_vision_base.py +17 -17
  338. intentkit/skills/venice_image/image_vision/image_vision_input.py +9 -9
  339. intentkit/skills/venice_image/schema.json +267 -267
  340. intentkit/skills/venice_image/utils.py +77 -78
  341. intentkit/skills/web_scraper/__init__.py +5 -18
  342. intentkit/skills/web_scraper/base.py +21 -7
  343. intentkit/skills/web_scraper/document_indexer.py +7 -6
  344. intentkit/skills/web_scraper/schema.json +2 -6
  345. intentkit/skills/web_scraper/scrape_and_index.py +15 -15
  346. intentkit/skills/web_scraper/utils.py +62 -63
  347. intentkit/skills/web_scraper/website_indexer.py +17 -19
  348. intentkit/skills/weth/__init__.py +49 -0
  349. intentkit/skills/weth/base.py +11 -0
  350. intentkit/skills/weth/schema.json +58 -0
  351. intentkit/skills/weth/weth.svg +6 -0
  352. intentkit/skills/wow/__init__.py +51 -0
  353. intentkit/skills/wow/base.py +11 -0
  354. intentkit/skills/wow/schema.json +89 -0
  355. intentkit/skills/wow/wow.svg +7 -0
  356. intentkit/skills/x402/__init__.py +61 -0
  357. intentkit/skills/x402/ask_agent.py +98 -0
  358. intentkit/skills/x402/base.py +99 -0
  359. intentkit/skills/x402/http_request.py +117 -0
  360. intentkit/skills/x402/schema.json +45 -0
  361. intentkit/skills/x402/x402.webp +0 -0
  362. intentkit/skills/xmtp/__init__.py +4 -15
  363. intentkit/skills/xmtp/base.py +61 -2
  364. intentkit/skills/xmtp/price.py +18 -13
  365. intentkit/skills/xmtp/schema.json +69 -71
  366. intentkit/skills/xmtp/swap.py +22 -25
  367. intentkit/skills/xmtp/transfer.py +71 -32
  368. intentkit/utils/chain.py +3 -3
  369. intentkit/utils/error.py +14 -1
  370. intentkit/utils/logging.py +2 -4
  371. intentkit/utils/s3.py +59 -7
  372. intentkit/utils/schema.py +100 -0
  373. intentkit/utils/slack_alert.py +7 -8
  374. {intentkit-0.6.13.dev2.dist-info → intentkit-0.8.17.dist-info}/METADATA +14 -16
  375. intentkit-0.8.17.dist-info/RECORD +466 -0
  376. intentkit/abstracts/exception.py +0 -9
  377. intentkit/core/skill.py +0 -200
  378. intentkit/models/generator.py +0 -347
  379. intentkit/skills/cdp/get_balance.py +0 -110
  380. intentkit/skills/cdp/swap.py +0 -121
  381. intentkit/skills/moralis/tests/__init__.py +0 -0
  382. intentkit/skills/moralis/tests/test_wallet.py +0 -511
  383. intentkit-0.6.13.dev2.dist-info/RECORD +0 -409
  384. {intentkit-0.6.13.dev2.dist-info → intentkit-0.8.17.dist-info}/WHEEL +0 -0
  385. {intentkit-0.6.13.dev2.dist-info → intentkit-0.8.17.dist-info}/licenses/LICENSE +0 -0
@@ -1,7 +1,5 @@
1
1
  """Tool for fetching all protocols via DeFi Llama API."""
2
2
 
3
- from typing import Dict, List, Optional, Type, Union
4
-
5
3
  from pydantic import BaseModel, Field
6
4
 
7
5
  from intentkit.skills.defillama.api import fetch_protocols
@@ -35,89 +33,83 @@ class Protocol(BaseModel):
35
33
  # Basic Info
36
34
  id: str = Field(..., description="Protocol unique identifier")
37
35
  name: str = Field(..., description="Protocol name")
38
- address: Optional[str] = Field(None, description="Protocol's main contract address")
36
+ address: str | None = Field(None, description="Protocol's main contract address")
39
37
  symbol: str = Field(..., description="Protocol token symbol")
40
- url: Optional[str] = Field(None, description="Protocol website")
41
- description: Optional[str] = Field(None, description="Protocol description")
42
- chain: Optional[str] = Field(None, description="Main chain of the protocol")
43
- logo: Optional[str] = Field(None, description="URL to protocol logo")
38
+ url: str | None = Field(None, description="Protocol website")
39
+ description: str | None = Field(None, description="Protocol description")
40
+ chain: str | None = Field(None, description="Main chain of the protocol")
41
+ logo: str | None = Field(None, description="URL to protocol logo")
44
42
 
45
43
  # Audit Information
46
- audits: Union[str, int] = Field("0", description="Number of audits")
47
- audit_note: Optional[str] = Field(None, description="Additional audit information")
48
- audit_links: Optional[List[str]] = Field(None, description="Links to audit reports")
44
+ audits: str | int = Field("0", description="Number of audits")
45
+ audit_note: str | None = Field(None, description="Additional audit information")
46
+ audit_links: list[str] | None = Field(None, description="Links to audit reports")
49
47
 
50
48
  # External IDs
51
- gecko_id: Optional[str] = Field(None, description="CoinGecko ID")
52
- cmcId: Optional[Union[str, int]] = Field(None, description="CoinMarketCap ID")
49
+ gecko_id: str | None = Field(None, description="CoinGecko ID")
50
+ cmcId: str | int | None = Field(None, description="CoinMarketCap ID")
53
51
 
54
52
  # Classification
55
53
  category: str = Field(..., description="Protocol category")
56
- chains: List[str] = Field(
54
+ chains: list[str] = Field(
57
55
  default_factory=list, description="Chains the protocol operates on"
58
56
  )
59
57
 
60
58
  # Module and Related Info
61
59
  module: str = Field(..., description="Module name in DefiLlama")
62
- parentProtocol: Optional[str] = Field(
63
- None, description="Parent protocol identifier"
64
- )
60
+ parentProtocol: str | None = Field(None, description="Parent protocol identifier")
65
61
 
66
62
  # Social and Development
67
- twitter: Optional[str] = Field(None, description="Twitter handle")
68
- github: Optional[List[str]] = Field(None, description="GitHub organization names")
63
+ twitter: str | None = Field(None, description="Twitter handle")
64
+ github: list[str] | None = Field(None, description="GitHub organization names")
69
65
 
70
66
  # Protocol Relationships
71
- oracles: List[str] = Field(default_factory=list, description="Oracle services used")
72
- forkedFrom: List[str] = Field(
67
+ oracles: list[str] = Field(default_factory=list, description="Oracle services used")
68
+ forkedFrom: list[str] = Field(
73
69
  default_factory=list, description="Protocols this one was forked from"
74
70
  )
75
71
 
76
72
  # Additional Metadata
77
- methodology: Optional[str] = Field(None, description="TVL calculation methodology")
78
- listedAt: Optional[int] = Field(
79
- None, description="Timestamp when protocol was listed"
80
- )
81
- openSource: Optional[bool] = Field(
82
- None, description="Whether protocol is open source"
83
- )
84
- treasury: Optional[str] = Field(None, description="Treasury information")
85
- misrepresentedTokens: Optional[bool] = Field(
73
+ methodology: str | None = Field(None, description="TVL calculation methodology")
74
+ listedAt: int | None = Field(None, description="Timestamp when protocol was listed")
75
+ openSource: bool | None = Field(None, description="Whether protocol is open source")
76
+ treasury: str | None = Field(None, description="Treasury information")
77
+ misrepresentedTokens: bool | None = Field(
86
78
  None, description="Whether tokens are misrepresented"
87
79
  )
88
- hallmarks: Optional[List[Hallmark]] = Field(
80
+ hallmarks: list[Hallmark] | None = Field(
89
81
  None, description="Significant protocol events"
90
82
  )
91
83
 
92
84
  # TVL Related Data
93
- tvl: Optional[float] = Field(None, description="Total Value Locked in USD")
94
- chainTvls: Dict[str, float] = Field(
85
+ tvl: float | None = Field(None, description="Total Value Locked in USD")
86
+ chainTvls: dict[str, float] = Field(
95
87
  default_factory=dict,
96
88
  description="TVL breakdown by chain including special types (staking, borrowed, etc.)",
97
89
  )
98
- change_1h: Optional[float] = Field(None, description="1 hour TVL change percentage")
99
- change_1d: Optional[float] = Field(None, description="1 day TVL change percentage")
100
- change_7d: Optional[float] = Field(None, description="7 day TVL change percentage")
90
+ change_1h: float | None = Field(None, description="1 hour TVL change percentage")
91
+ change_1d: float | None = Field(None, description="1 day TVL change percentage")
92
+ change_7d: float | None = Field(None, description="7 day TVL change percentage")
101
93
 
102
94
  # Additional TVL Components
103
- staking: Optional[float] = Field(None, description="Value in staking")
104
- pool2: Optional[float] = Field(None, description="Value in pool2")
105
- borrowed: Optional[float] = Field(None, description="Value borrowed")
95
+ staking: float | None = Field(None, description="Value in staking")
96
+ pool2: float | None = Field(None, description="Value in pool2")
97
+ borrowed: float | None = Field(None, description="Value borrowed")
106
98
 
107
99
  # Token Information
108
- tokenBreakdowns: Dict[str, float] = Field(
100
+ tokenBreakdowns: dict[str, float] = Field(
109
101
  default_factory=dict, description="TVL breakdown by token"
110
102
  )
111
- mcap: Optional[float] = Field(None, description="Market capitalization")
103
+ mcap: float | None = Field(None, description="Market capitalization")
112
104
 
113
105
 
114
106
  class DefiLlamaProtocolsOutput(BaseModel):
115
107
  """Output model for the protocols fetching tool."""
116
108
 
117
- protocols: List[Protocol] = Field(
109
+ protocols: list[Protocol] = Field(
118
110
  default_factory=list, description="List of fetched protocols"
119
111
  )
120
- error: Optional[str] = Field(None, description="Error message if any")
112
+ error: str | None = Field(None, description="Error message if any")
121
113
 
122
114
 
123
115
  class DefiLlamaFetchProtocols(DefiLlamaBaseTool):
@@ -128,9 +120,9 @@ class DefiLlamaFetchProtocols(DefiLlamaBaseTool):
128
120
 
129
121
  Example:
130
122
  protocols_tool = DefiLlamaFetchProtocols(
131
- skill_store=store,
123
+ ,
132
124
  agent_id="agent_123",
133
- agent_store=agent_store
125
+ agent=agent
134
126
  )
135
127
  result = await protocols_tool._arun()
136
128
  """
@@ -143,7 +135,7 @@ class DefiLlamaFetchProtocols(DefiLlamaBaseTool):
143
135
 
144
136
  pass
145
137
 
146
- args_schema: Type[BaseModel] = EmptyArgsSchema
138
+ args_schema: type[BaseModel] = EmptyArgsSchema
147
139
 
148
140
  async def _arun(self, **kwargs) -> DefiLlamaProtocolsOutput:
149
141
  """Fetch information about all protocols.
@@ -1,7 +1,5 @@
1
1
  """Tool for fetching DEX overview 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_dex_overview
@@ -20,78 +18,74 @@ Returns:
20
18
  class MethodologyInfo(BaseModel):
21
19
  """Model representing methodology information."""
22
20
 
23
- UserFees: Optional[str] = Field(None, description="User fee information")
24
- Fees: Optional[str] = Field(None, description="Fee structure")
25
- Revenue: Optional[str] = Field(None, description="Revenue model")
26
- ProtocolRevenue: Optional[str] = Field(None, description="Protocol revenue info")
27
- HoldersRevenue: Optional[str] = Field(None, description="Holder revenue info")
28
- SupplySideRevenue: Optional[str] = Field(
29
- None, description="Supply side revenue info"
30
- )
21
+ UserFees: str | None = Field(None, description="User fee information")
22
+ Fees: str | None = Field(None, description="Fee structure")
23
+ Revenue: str | None = Field(None, description="Revenue model")
24
+ ProtocolRevenue: str | None = Field(None, description="Protocol revenue info")
25
+ HoldersRevenue: str | None = Field(None, description="Holder revenue info")
26
+ SupplySideRevenue: str | None = Field(None, description="Supply side revenue info")
31
27
 
32
28
 
33
29
  class ProtocolInfo(BaseModel):
34
30
  """Model representing individual protocol data."""
35
31
 
36
- total24h: Optional[float] = Field(None, description="24h total")
37
- total48hto24h: Optional[float] = Field(None, description="48h to 24h total")
38
- total7d: Optional[float] = Field(None, description="7d total")
39
- total14dto7d: Optional[float] = Field(None, description="14d to 7d total")
40
- total60dto30d: Optional[float] = Field(None, description="60d to 30d total")
41
- total30d: Optional[float] = Field(None, description="30d total")
42
- total1y: Optional[float] = Field(None, description="1y total")
43
- totalAllTime: Optional[float] = Field(None, description="All time total")
44
- average1y: Optional[float] = Field(None, description="1y average")
45
- change_1d: Optional[float] = Field(None, description="1d change")
46
- change_7d: Optional[float] = Field(None, description="7d change")
47
- change_1m: Optional[float] = Field(None, description="1m change")
48
- change_7dover7d: Optional[float] = Field(None, description="7d over 7d change")
49
- change_30dover30d: Optional[float] = Field(None, description="30d over 30d change")
50
- breakdown24h: Optional[Dict[str, Dict[str, float]]] = Field(
32
+ total24h: float | None = Field(None, description="24h total")
33
+ total48hto24h: float | None = Field(None, description="48h to 24h total")
34
+ total7d: float | None = Field(None, description="7d total")
35
+ total14dto7d: float | None = Field(None, description="14d to 7d total")
36
+ total60dto30d: float | None = Field(None, description="60d to 30d total")
37
+ total30d: float | None = Field(None, description="30d total")
38
+ total1y: float | None = Field(None, description="1y total")
39
+ totalAllTime: float | None = Field(None, description="All time total")
40
+ average1y: float | None = Field(None, description="1y average")
41
+ change_1d: float | None = Field(None, description="1d change")
42
+ change_7d: float | None = Field(None, description="7d change")
43
+ change_1m: float | None = Field(None, description="1m change")
44
+ change_7dover7d: float | None = Field(None, description="7d over 7d change")
45
+ change_30dover30d: float | None = Field(None, description="30d over 30d change")
46
+ breakdown24h: dict[str, dict[str, float]] | None = Field(
51
47
  None, description="24h breakdown by chain"
52
48
  )
53
- breakdown30d: Optional[Dict[str, Dict[str, float]]] = Field(
49
+ breakdown30d: dict[str, dict[str, float]] | None = Field(
54
50
  None, description="30d breakdown by chain"
55
51
  )
56
- total7DaysAgo: Optional[float] = Field(None, description="Total 7 days ago")
57
- total30DaysAgo: Optional[float] = Field(None, description="Total 30 days ago")
58
- defillamaId: Optional[str] = Field(None, description="DeFi Llama ID")
52
+ total7DaysAgo: float | None = Field(None, description="Total 7 days ago")
53
+ total30DaysAgo: float | None = Field(None, description="Total 30 days ago")
54
+ defillamaId: str | None = Field(None, description="DeFi Llama ID")
59
55
  name: str = Field(..., description="Protocol name")
60
56
  displayName: str = Field(..., description="Display name")
61
57
  module: str = Field(..., description="Module name")
62
58
  category: str = Field(..., description="Protocol category")
63
- logo: Optional[str] = Field(None, description="Logo URL")
64
- chains: List[str] = Field(..., description="Supported chains")
59
+ logo: str | None = Field(None, description="Logo URL")
60
+ chains: list[str] = Field(..., description="Supported chains")
65
61
  protocolType: str = Field(..., description="Protocol type")
66
- methodologyURL: Optional[str] = Field(None, description="Methodology URL")
67
- methodology: Optional[MethodologyInfo] = Field(
68
- None, description="Methodology details"
69
- )
62
+ methodologyURL: str | None = Field(None, description="Methodology URL")
63
+ methodology: MethodologyInfo | None = Field(None, description="Methodology details")
70
64
  latestFetchIsOk: bool = Field(..., description="Latest fetch status")
71
- disabled: Optional[bool] = Field(None, description="Whether protocol is disabled")
72
- parentProtocol: Optional[str] = Field(None, description="Parent protocol")
65
+ disabled: bool | None = Field(None, description="Whether protocol is disabled")
66
+ parentProtocol: str | None = Field(None, description="Parent protocol")
73
67
  slug: str = Field(..., description="Protocol slug")
74
- linkedProtocols: Optional[List[str]] = Field(None, description="Linked protocols")
68
+ linkedProtocols: list[str] | None = Field(None, description="Linked protocols")
75
69
  id: str = Field(..., description="Protocol ID")
76
70
 
77
71
 
78
72
  class FetchDexOverviewResponse(BaseModel):
79
73
  """Response schema for DEX overview data."""
80
74
 
81
- totalDataChart: List = Field(
75
+ totalDataChart: list = Field(
82
76
  default_factory=list, description="Total data chart points"
83
77
  )
84
- totalDataChartBreakdown: List = Field(
78
+ totalDataChartBreakdown: list = Field(
85
79
  default_factory=list, description="Total data chart breakdown"
86
80
  )
87
- breakdown24h: Optional[Dict[str, Dict[str, float]]] = Field(
81
+ breakdown24h: dict[str, dict[str, float]] | None = Field(
88
82
  None, description="24h breakdown by chain"
89
83
  )
90
- breakdown30d: Optional[Dict[str, Dict[str, float]]] = Field(
84
+ breakdown30d: dict[str, dict[str, float]] | None = Field(
91
85
  None, description="30d breakdown by chain"
92
86
  )
93
- chain: Optional[str] = Field(None, description="Specific chain")
94
- allChains: List[str] = Field(..., description="List of all chains")
87
+ chain: str | None = Field(None, description="Specific chain")
88
+ allChains: list[str] = Field(..., description="List of all chains")
95
89
  total24h: float = Field(..., description="24h total")
96
90
  total48hto24h: float = Field(..., description="48h to 24h total")
97
91
  total7d: float = Field(..., description="7d total")
@@ -106,8 +100,8 @@ class FetchDexOverviewResponse(BaseModel):
106
100
  change_30dover30d: float = Field(..., description="30d over 30d change")
107
101
  total7DaysAgo: float = Field(..., description="Total 7 days ago")
108
102
  total30DaysAgo: float = Field(..., description="Total 30 days ago")
109
- protocols: List[ProtocolInfo] = Field(..., description="List of protocol data")
110
- error: Optional[str] = Field(None, description="Error message if any")
103
+ protocols: list[ProtocolInfo] = Field(..., description="List of protocol data")
104
+ error: str | None = Field(None, description="Error message if any")
111
105
 
112
106
 
113
107
  class DefiLlamaFetchDexOverview(DefiLlamaBaseTool):
@@ -118,9 +112,9 @@ class DefiLlamaFetchDexOverview(DefiLlamaBaseTool):
118
112
 
119
113
  Example:
120
114
  overview_tool = DefiLlamaFetchDexOverview(
121
- skill_store=store,
115
+ ,
122
116
  agent_id="agent_123",
123
- agent_store=agent_store
117
+ agent=agent
124
118
  )
125
119
  result = await overview_tool._arun()
126
120
  """
@@ -1,7 +1,5 @@
1
1
  """Tool for fetching DEX protocol summary 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_dex_summary
@@ -30,44 +28,44 @@ class FetchDexSummaryResponse(BaseModel):
30
28
 
31
29
  id: str = Field(..., description="Protocol ID")
32
30
  name: str = Field(..., description="Protocol name")
33
- url: Optional[str] = Field(None, description="Protocol website URL")
34
- description: Optional[str] = Field(None, description="Protocol description")
35
- logo: Optional[str] = Field(None, description="Logo URL")
36
- gecko_id: Optional[str] = Field(None, description="CoinGecko ID")
37
- cmcId: Optional[str] = Field(None, description="CoinMarketCap ID")
38
- chains: List[str] = Field(default_factory=list, description="Supported chains")
39
- twitter: Optional[str] = Field(None, description="Twitter handle")
40
- treasury: Optional[str] = Field(None, description="Treasury identifier")
41
- governanceID: Optional[List[str]] = Field(None, description="Governance IDs")
42
- github: Optional[List[str]] = Field(None, description="GitHub organizations")
43
- childProtocols: Optional[List[str]] = Field(None, description="Child protocols")
44
- linkedProtocols: Optional[List[str]] = Field(None, description="Linked protocols")
45
- disabled: Optional[bool] = Field(None, description="Whether protocol is disabled")
31
+ url: str | None = Field(None, description="Protocol website URL")
32
+ description: str | None = Field(None, description="Protocol description")
33
+ logo: str | None = Field(None, description="Logo URL")
34
+ gecko_id: str | None = Field(None, description="CoinGecko ID")
35
+ cmcId: str | None = Field(None, description="CoinMarketCap ID")
36
+ chains: list[str] = Field(default_factory=list, description="Supported chains")
37
+ twitter: str | None = Field(None, description="Twitter handle")
38
+ treasury: str | None = Field(None, description="Treasury identifier")
39
+ governanceID: list[str] | None = Field(None, description="Governance IDs")
40
+ github: list[str] | None = Field(None, description="GitHub organizations")
41
+ childProtocols: list[str] | None = Field(None, description="Child protocols")
42
+ linkedProtocols: list[str] | None = Field(None, description="Linked protocols")
43
+ disabled: bool | None = Field(None, description="Whether protocol is disabled")
46
44
  displayName: str = Field(..., description="Display name")
47
- module: Optional[str] = Field(None, description="Module name")
48
- category: Optional[str] = Field(None, description="Protocol category")
49
- methodologyURL: Optional[str] = Field(None, description="Methodology URL")
50
- methodology: Optional[Dict] = Field(None, description="Methodology details")
51
- forkedFrom: Optional[List[str]] = Field(None, description="Forked from protocols")
52
- audits: Optional[str] = Field(None, description="Audit information")
53
- address: Optional[str] = Field(None, description="Contract address")
54
- audit_links: Optional[List[str]] = Field(None, description="Audit links")
55
- versionKey: Optional[str] = Field(None, description="Version key")
56
- parentProtocol: Optional[str] = Field(None, description="Parent protocol")
57
- previousNames: Optional[List[str]] = Field(None, description="Previous names")
45
+ module: str | None = Field(None, description="Module name")
46
+ category: str | None = Field(None, description="Protocol category")
47
+ methodologyURL: str | None = Field(None, description="Methodology URL")
48
+ methodology: dict | None = Field(None, description="Methodology details")
49
+ forkedFrom: list[str] | None = Field(None, description="Forked from protocols")
50
+ audits: str | None = Field(None, description="Audit information")
51
+ address: str | None = Field(None, description="Contract address")
52
+ audit_links: list[str] | None = Field(None, description="Audit links")
53
+ versionKey: str | None = Field(None, description="Version key")
54
+ parentProtocol: str | None = Field(None, description="Parent protocol")
55
+ previousNames: list[str] | None = Field(None, description="Previous names")
58
56
  latestFetchIsOk: bool = Field(..., description="Latest fetch status")
59
57
  slug: str = Field(..., description="Protocol slug")
60
58
  protocolType: str = Field(..., description="Protocol type")
61
- total24h: Optional[float] = Field(None, description="24h total volume")
62
- total48hto24h: Optional[float] = Field(None, description="48h to 24h total volume")
63
- total7d: Optional[float] = Field(None, description="7d total volume")
64
- totalAllTime: Optional[float] = Field(None, description="All time total volume")
65
- totalDataChart: List = Field(default_factory=list, description="Total data chart")
66
- totalDataChartBreakdown: List = Field(
59
+ total24h: float | None = Field(None, description="24h total volume")
60
+ total48hto24h: float | None = Field(None, description="48h to 24h total volume")
61
+ total7d: float | None = Field(None, description="7d total volume")
62
+ totalAllTime: float | None = Field(None, description="All time total volume")
63
+ totalDataChart: list = Field(default_factory=list, description="Total data chart")
64
+ totalDataChartBreakdown: list = Field(
67
65
  default_factory=list, description="Chart breakdown"
68
66
  )
69
- change_1d: Optional[float] = Field(None, description="1d change percentage")
70
- error: Optional[str] = Field(None, description="Error message if any")
67
+ change_1d: float | None = Field(None, description="1d change percentage")
68
+ error: str | None = Field(None, description="Error message if any")
71
69
 
72
70
 
73
71
  class DefiLlamaFetchDexSummary(DefiLlamaBaseTool):
@@ -78,16 +76,16 @@ class DefiLlamaFetchDexSummary(DefiLlamaBaseTool):
78
76
 
79
77
  Example:
80
78
  summary_tool = DefiLlamaFetchDexSummary(
81
- skill_store=store,
79
+ ,
82
80
  agent_id="agent_123",
83
- agent_store=agent_store
81
+ agent=agent
84
82
  )
85
83
  result = await summary_tool._arun(protocol="uniswap")
86
84
  """
87
85
 
88
86
  name: str = "defillama_fetch_dex_summary"
89
87
  description: str = FETCH_DEX_SUMMARY_PROMPT
90
- args_schema: Type[BaseModel] = FetchDexSummaryInput
88
+ args_schema: type[BaseModel] = FetchDexSummaryInput
91
89
 
92
90
  async def _arun(self, protocol: str) -> FetchDexSummaryResponse:
93
91
  """Fetch summary data for the given DEX protocol.
@@ -1,7 +1,5 @@
1
1
  """Tool for fetching options 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_options_overview
@@ -20,16 +18,14 @@ 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="User fees description")
24
- Fees: Optional[str] = Field(None, description="Fees description")
25
- Revenue: Optional[str] = Field(None, description="Revenue description")
26
- ProtocolRevenue: Optional[str] = Field(
21
+ UserFees: str | None = Field(None, description="User fees description")
22
+ Fees: str | None = Field(None, description="Fees description")
23
+ Revenue: str | None = Field(None, description="Revenue description")
24
+ ProtocolRevenue: str | None = Field(
27
25
  None, description="Protocol revenue description"
28
26
  )
29
- HoldersRevenue: Optional[str] = Field(
30
- None, description="Holders revenue description"
31
- )
32
- SupplySideRevenue: Optional[str] = Field(
27
+ HoldersRevenue: str | None = Field(None, description="Holders revenue description")
28
+ SupplySideRevenue: str | None = Field(
33
29
  None, description="Supply side revenue description"
34
30
  )
35
31
 
@@ -42,23 +38,23 @@ class Protocol(BaseModel):
42
38
  defillamaId: str = Field(..., description="DeFi Llama ID")
43
39
  category: str = Field(..., description="Protocol category")
44
40
  logo: str = Field(..., description="Logo URL")
45
- chains: List[str] = Field(..., description="Supported chains")
41
+ chains: list[str] = Field(..., description="Supported chains")
46
42
  module: str = Field(..., description="Protocol module")
47
- total24h: Optional[float] = Field(None, description="24-hour total")
48
- total7d: Optional[float] = Field(None, description="7-day total")
49
- total30d: Optional[float] = Field(None, description="30-day total")
50
- total1y: Optional[float] = Field(None, description="1-year total")
51
- totalAllTime: Optional[float] = Field(None, description="All-time total")
52
- change_1d: Optional[float] = Field(None, description="24-hour change percentage")
53
- change_7d: Optional[float] = Field(None, description="7-day change percentage")
54
- change_1m: Optional[float] = Field(None, description="30-day change percentage")
55
- methodology: Optional[ProtocolMethodology] = Field(
43
+ total24h: float | None = Field(None, description="24-hour total")
44
+ total7d: float | None = Field(None, description="7-day total")
45
+ total30d: float | None = Field(None, description="30-day total")
46
+ total1y: float | None = Field(None, description="1-year total")
47
+ totalAllTime: float | None = Field(None, description="All-time total")
48
+ change_1d: float | None = Field(None, description="24-hour change percentage")
49
+ change_7d: float | None = Field(None, description="7-day change percentage")
50
+ change_1m: float | None = Field(None, description="30-day change percentage")
51
+ methodology: ProtocolMethodology | None = Field(
56
52
  None, description="Protocol methodology"
57
53
  )
58
- breakdown24h: Optional[Dict[str, Dict[str, float]]] = Field(
54
+ breakdown24h: dict[str, dict[str, float]] | None = Field(
59
55
  None, description="24-hour breakdown by chain"
60
56
  )
61
- breakdown30d: Optional[Dict[str, Dict[str, float]]] = Field(
57
+ breakdown30d: dict[str, dict[str, float]] | None = Field(
62
58
  None, description="30-day breakdown by chain"
63
59
  )
64
60
 
@@ -73,9 +69,9 @@ class FetchOptionsOverviewResponse(BaseModel):
73
69
  change_1d: float = Field(..., description="24-hour change percentage")
74
70
  change_7d: float = Field(..., description="7-day change percentage")
75
71
  change_1m: float = Field(..., description="30-day change percentage")
76
- allChains: List[str] = Field(..., description="List of all chains")
77
- protocols: List[Protocol] = Field(..., description="List of protocols")
78
- error: Optional[str] = Field(None, description="Error message if any")
72
+ allChains: list[str] = Field(..., description="List of all chains")
73
+ protocols: list[Protocol] = Field(..., description="List of protocols")
74
+ error: str | None = Field(None, description="Error message if any")
79
75
 
80
76
 
81
77
  class DefiLlamaFetchOptionsOverview(DefiLlamaBaseTool):
@@ -86,9 +82,9 @@ class DefiLlamaFetchOptionsOverview(DefiLlamaBaseTool):
86
82
 
87
83
  Example:
88
84
  overview_tool = DefiLlamaFetchOptionsOverview(
89
- skill_store=store,
85
+ ,
90
86
  agent_id="agent_123",
91
- agent_store=agent_store
87
+ agent=agent
92
88
  )
93
89
  result = await overview_tool._arun()
94
90
  """
@@ -101,7 +97,7 @@ class DefiLlamaFetchOptionsOverview(DefiLlamaBaseTool):
101
97
 
102
98
  pass
103
99
 
104
- args_schema: Type[BaseModel] = EmptyArgsSchema
100
+ args_schema: type[BaseModel] = EmptyArgsSchema
105
101
 
106
102
  async def _arun(self, **kwargs) -> FetchOptionsOverviewResponse:
107
103
  """Fetch overview data for all options protocols.
@@ -1,7 +1,5 @@
1
1
  """Tool for fetching pool chart data 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_pool_chart
@@ -23,11 +21,11 @@ class PoolDataPoint(BaseModel):
23
21
 
24
22
  timestamp: str = Field(..., description="ISO formatted timestamp of the data point")
25
23
  tvlUsd: float = Field(..., description="Total Value Locked in USD")
26
- apy: Optional[float] = Field(None, description="Total APY including rewards")
27
- apyBase: Optional[float] = Field(None, description="Base APY without rewards")
28
- apyReward: Optional[float] = Field(None, description="Additional APY from rewards")
29
- il7d: Optional[float] = Field(None, description="7-day impermanent loss")
30
- apyBase7d: Optional[float] = Field(None, description="7-day base APY")
24
+ apy: float | None = Field(None, description="Total APY including rewards")
25
+ apyBase: float | None = Field(None, description="Base APY without rewards")
26
+ apyReward: float | None = Field(None, description="Additional APY from rewards")
27
+ il7d: float | None = Field(None, description="7-day impermanent loss")
28
+ apyBase7d: float | None = Field(None, description="7-day base APY")
31
29
 
32
30
 
33
31
  class FetchPoolChartInput(BaseModel):
@@ -40,10 +38,10 @@ class FetchPoolChartResponse(BaseModel):
40
38
  """Response schema for pool chart data."""
41
39
 
42
40
  status: str = Field("success", description="Response status")
43
- data: List[PoolDataPoint] = Field(
41
+ data: list[PoolDataPoint] = Field(
44
42
  default_factory=list, description="List of historical data points"
45
43
  )
46
- error: Optional[str] = Field(None, description="Error message if any")
44
+ error: str | None = Field(None, description="Error message if any")
47
45
 
48
46
 
49
47
  class DefiLlamaFetchPoolChart(DefiLlamaBaseTool):
@@ -54,9 +52,9 @@ class DefiLlamaFetchPoolChart(DefiLlamaBaseTool):
54
52
 
55
53
  Example:
56
54
  chart_tool = DefiLlamaFetchPoolChart(
57
- skill_store=store,
55
+ ,
58
56
  agent_id="agent_123",
59
- agent_store=agent_store
57
+ agent=agent
60
58
  )
61
59
  result = await chart_tool._arun(
62
60
  pool_id="747c1d2a-c668-4682-b9f9-296708a3dd90"
@@ -65,7 +63,7 @@ class DefiLlamaFetchPoolChart(DefiLlamaBaseTool):
65
63
 
66
64
  name: str = "defillama_fetch_pool_chart"
67
65
  description: str = FETCH_POOL_CHART_PROMPT
68
- args_schema: Type[BaseModel] = FetchPoolChartInput
66
+ args_schema: type[BaseModel] = FetchPoolChartInput
69
67
 
70
68
  async def _arun(self, pool_id: str) -> FetchPoolChartResponse:
71
69
  """Fetch historical chart data for the given pool.