intentkit 0.7.5.dev3__py3-none-any.whl → 0.8.34.dev7__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.
Files changed (393) hide show
  1. intentkit/MANIFEST.in +14 -0
  2. intentkit/README.md +88 -0
  3. intentkit/__init__.py +6 -4
  4. intentkit/abstracts/agent.py +4 -5
  5. intentkit/abstracts/engine.py +5 -5
  6. intentkit/abstracts/graph.py +15 -8
  7. intentkit/abstracts/skill.py +6 -144
  8. intentkit/abstracts/twitter.py +4 -5
  9. intentkit/clients/__init__.py +9 -2
  10. intentkit/clients/cdp.py +129 -153
  11. intentkit/{utils → clients}/s3.py +109 -34
  12. intentkit/clients/twitter.py +83 -62
  13. intentkit/clients/web3.py +4 -7
  14. intentkit/config/config.py +123 -90
  15. intentkit/core/account_checking.py +802 -0
  16. intentkit/core/agent.py +313 -498
  17. intentkit/core/asset.py +267 -0
  18. intentkit/core/chat.py +5 -3
  19. intentkit/core/client.py +1 -1
  20. intentkit/core/credit.py +49 -41
  21. intentkit/core/draft.py +201 -0
  22. intentkit/core/draft_chat.py +118 -0
  23. intentkit/core/engine.py +378 -287
  24. intentkit/core/manager/__init__.py +25 -0
  25. intentkit/core/manager/engine.py +220 -0
  26. intentkit/core/manager/service.py +172 -0
  27. intentkit/core/manager/skills.py +178 -0
  28. intentkit/core/middleware.py +231 -0
  29. intentkit/core/prompt.py +74 -114
  30. intentkit/core/scheduler.py +143 -0
  31. intentkit/core/statistics.py +168 -0
  32. intentkit/models/agent.py +931 -518
  33. intentkit/models/agent_data.py +165 -106
  34. intentkit/models/agent_schema.json +38 -251
  35. intentkit/models/app_setting.py +15 -13
  36. intentkit/models/chat.py +86 -140
  37. intentkit/models/credit.py +182 -162
  38. intentkit/models/db.py +42 -23
  39. intentkit/models/db_mig.py +120 -3
  40. intentkit/models/draft.py +222 -0
  41. intentkit/models/llm.csv +31 -0
  42. intentkit/models/llm.py +262 -370
  43. intentkit/models/redis.py +6 -4
  44. intentkit/models/skill.py +222 -101
  45. intentkit/models/skills.csv +173 -0
  46. intentkit/models/team.py +189 -0
  47. intentkit/models/user.py +103 -31
  48. intentkit/skills/acolyt/__init__.py +2 -9
  49. intentkit/skills/acolyt/ask.py +3 -4
  50. intentkit/skills/acolyt/base.py +4 -9
  51. intentkit/skills/acolyt/schema.json +4 -3
  52. intentkit/skills/aixbt/__init__.py +2 -13
  53. intentkit/skills/aixbt/base.py +1 -7
  54. intentkit/skills/aixbt/projects.py +14 -15
  55. intentkit/skills/aixbt/schema.json +4 -4
  56. intentkit/skills/allora/__init__.py +2 -9
  57. intentkit/skills/allora/base.py +4 -9
  58. intentkit/skills/allora/price.py +3 -4
  59. intentkit/skills/allora/schema.json +3 -2
  60. intentkit/skills/base.py +241 -41
  61. intentkit/skills/basename/__init__.py +51 -0
  62. intentkit/skills/basename/base.py +11 -0
  63. intentkit/skills/basename/basename.svg +11 -0
  64. intentkit/skills/basename/schema.json +58 -0
  65. intentkit/skills/carv/__init__.py +115 -121
  66. intentkit/skills/carv/base.py +184 -185
  67. intentkit/skills/carv/fetch_news.py +3 -3
  68. intentkit/skills/carv/onchain_query.py +4 -4
  69. intentkit/skills/carv/schema.json +134 -137
  70. intentkit/skills/carv/token_info_and_price.py +6 -6
  71. intentkit/skills/casino/__init__.py +4 -15
  72. intentkit/skills/casino/base.py +1 -7
  73. intentkit/skills/casino/deck_draw.py +5 -8
  74. intentkit/skills/casino/deck_shuffle.py +6 -6
  75. intentkit/skills/casino/dice_roll.py +2 -4
  76. intentkit/skills/casino/schema.json +0 -1
  77. intentkit/skills/cdp/__init__.py +22 -84
  78. intentkit/skills/cdp/base.py +1 -7
  79. intentkit/skills/cdp/schema.json +11 -314
  80. intentkit/skills/chainlist/__init__.py +2 -7
  81. intentkit/skills/chainlist/base.py +1 -7
  82. intentkit/skills/chainlist/chain_lookup.py +18 -18
  83. intentkit/skills/chainlist/schema.json +3 -5
  84. intentkit/skills/common/__init__.py +2 -9
  85. intentkit/skills/common/base.py +1 -7
  86. intentkit/skills/common/current_time.py +1 -2
  87. intentkit/skills/common/schema.json +2 -2
  88. intentkit/skills/cookiefun/__init__.py +6 -9
  89. intentkit/skills/cookiefun/base.py +2 -7
  90. intentkit/skills/cookiefun/get_account_details.py +7 -7
  91. intentkit/skills/cookiefun/get_account_feed.py +19 -19
  92. intentkit/skills/cookiefun/get_account_smart_followers.py +7 -7
  93. intentkit/skills/cookiefun/get_sectors.py +3 -3
  94. intentkit/skills/cookiefun/schema.json +1 -3
  95. intentkit/skills/cookiefun/search_accounts.py +9 -9
  96. intentkit/skills/cryptocompare/__init__.py +7 -24
  97. intentkit/skills/cryptocompare/api.py +2 -3
  98. intentkit/skills/cryptocompare/base.py +10 -24
  99. intentkit/skills/cryptocompare/fetch_news.py +4 -5
  100. intentkit/skills/cryptocompare/fetch_price.py +6 -7
  101. intentkit/skills/cryptocompare/fetch_top_exchanges.py +4 -5
  102. intentkit/skills/cryptocompare/fetch_top_market_cap.py +4 -5
  103. intentkit/skills/cryptocompare/fetch_top_volume.py +4 -5
  104. intentkit/skills/cryptocompare/fetch_trading_signals.py +5 -6
  105. intentkit/skills/cryptocompare/schema.json +3 -3
  106. intentkit/skills/cryptopanic/__init__.py +7 -10
  107. intentkit/skills/cryptopanic/base.py +51 -55
  108. intentkit/skills/cryptopanic/fetch_crypto_news.py +4 -8
  109. intentkit/skills/cryptopanic/fetch_crypto_sentiment.py +5 -7
  110. intentkit/skills/cryptopanic/schema.json +105 -103
  111. intentkit/skills/dapplooker/__init__.py +2 -9
  112. intentkit/skills/dapplooker/base.py +4 -9
  113. intentkit/skills/dapplooker/dapplooker_token_data.py +7 -7
  114. intentkit/skills/dapplooker/schema.json +3 -5
  115. intentkit/skills/defillama/__init__.py +24 -74
  116. intentkit/skills/defillama/api.py +6 -9
  117. intentkit/skills/defillama/base.py +8 -19
  118. intentkit/skills/defillama/coins/fetch_batch_historical_prices.py +8 -10
  119. intentkit/skills/defillama/coins/fetch_block.py +6 -8
  120. intentkit/skills/defillama/coins/fetch_current_prices.py +8 -10
  121. intentkit/skills/defillama/coins/fetch_first_price.py +7 -9
  122. intentkit/skills/defillama/coins/fetch_historical_prices.py +9 -11
  123. intentkit/skills/defillama/coins/fetch_price_chart.py +9 -11
  124. intentkit/skills/defillama/coins/fetch_price_percentage.py +7 -9
  125. intentkit/skills/defillama/config/chains.py +1 -3
  126. intentkit/skills/defillama/fees/fetch_fees_overview.py +24 -26
  127. intentkit/skills/defillama/schema.json +5 -1
  128. intentkit/skills/defillama/stablecoins/fetch_stablecoin_chains.py +16 -18
  129. intentkit/skills/defillama/stablecoins/fetch_stablecoin_charts.py +8 -10
  130. intentkit/skills/defillama/stablecoins/fetch_stablecoin_prices.py +5 -7
  131. intentkit/skills/defillama/stablecoins/fetch_stablecoins.py +7 -9
  132. intentkit/skills/defillama/tests/api_integration.test.py +1 -1
  133. intentkit/skills/defillama/tvl/fetch_chain_historical_tvl.py +4 -6
  134. intentkit/skills/defillama/tvl/fetch_chains.py +9 -11
  135. intentkit/skills/defillama/tvl/fetch_historical_tvl.py +4 -6
  136. intentkit/skills/defillama/tvl/fetch_protocol.py +32 -38
  137. intentkit/skills/defillama/tvl/fetch_protocol_current_tvl.py +3 -5
  138. intentkit/skills/defillama/tvl/fetch_protocols.py +37 -45
  139. intentkit/skills/defillama/volumes/fetch_dex_overview.py +42 -48
  140. intentkit/skills/defillama/volumes/fetch_dex_summary.py +35 -37
  141. intentkit/skills/defillama/volumes/fetch_options_overview.py +24 -28
  142. intentkit/skills/defillama/yields/fetch_pool_chart.py +10 -12
  143. intentkit/skills/defillama/yields/fetch_pools.py +26 -30
  144. intentkit/skills/dexscreener/__init__.py +97 -102
  145. intentkit/skills/dexscreener/base.py +125 -130
  146. intentkit/skills/dexscreener/get_pair_info.py +4 -5
  147. intentkit/skills/dexscreener/get_token_pairs.py +4 -5
  148. intentkit/skills/dexscreener/get_tokens_info.py +7 -8
  149. intentkit/skills/dexscreener/model/search_token_response.py +80 -82
  150. intentkit/skills/dexscreener/schema.json +91 -93
  151. intentkit/skills/dexscreener/search_token.py +182 -184
  152. intentkit/skills/dexscreener/utils.py +15 -14
  153. intentkit/skills/dune_analytics/__init__.py +7 -9
  154. intentkit/skills/dune_analytics/base.py +48 -52
  155. intentkit/skills/dune_analytics/fetch_kol_buys.py +5 -7
  156. intentkit/skills/dune_analytics/fetch_nation_metrics.py +6 -8
  157. intentkit/skills/dune_analytics/schema.json +104 -99
  158. intentkit/skills/elfa/__init__.py +5 -18
  159. intentkit/skills/elfa/base.py +10 -14
  160. intentkit/skills/elfa/mention.py +19 -21
  161. intentkit/skills/elfa/schema.json +3 -2
  162. intentkit/skills/elfa/stats.py +4 -4
  163. intentkit/skills/elfa/tokens.py +12 -12
  164. intentkit/skills/elfa/utils.py +26 -28
  165. intentkit/skills/enso/__init__.py +11 -31
  166. intentkit/skills/enso/base.py +54 -35
  167. intentkit/skills/enso/best_yield.py +16 -24
  168. intentkit/skills/enso/networks.py +6 -11
  169. intentkit/skills/enso/prices.py +11 -13
  170. intentkit/skills/enso/route.py +34 -38
  171. intentkit/skills/enso/schema.json +3 -2
  172. intentkit/skills/enso/tokens.py +29 -38
  173. intentkit/skills/enso/wallet.py +76 -191
  174. intentkit/skills/erc20/__init__.py +50 -0
  175. intentkit/skills/erc20/base.py +11 -0
  176. intentkit/skills/erc20/erc20.svg +5 -0
  177. intentkit/skills/erc20/schema.json +74 -0
  178. intentkit/skills/erc721/__init__.py +53 -0
  179. intentkit/skills/erc721/base.py +11 -0
  180. intentkit/skills/erc721/erc721.svg +5 -0
  181. intentkit/skills/erc721/schema.json +90 -0
  182. intentkit/skills/firecrawl/__init__.py +5 -18
  183. intentkit/skills/firecrawl/base.py +4 -9
  184. intentkit/skills/firecrawl/clear.py +4 -8
  185. intentkit/skills/firecrawl/crawl.py +19 -19
  186. intentkit/skills/firecrawl/query.py +4 -3
  187. intentkit/skills/firecrawl/schema.json +2 -6
  188. intentkit/skills/firecrawl/scrape.py +17 -22
  189. intentkit/skills/firecrawl/utils.py +50 -42
  190. intentkit/skills/github/__init__.py +2 -7
  191. intentkit/skills/github/base.py +1 -7
  192. intentkit/skills/github/github_search.py +1 -2
  193. intentkit/skills/github/schema.json +3 -4
  194. intentkit/skills/heurist/__init__.py +8 -27
  195. intentkit/skills/heurist/base.py +4 -9
  196. intentkit/skills/heurist/image_generation_animagine_xl.py +13 -15
  197. intentkit/skills/heurist/image_generation_arthemy_comics.py +13 -15
  198. intentkit/skills/heurist/image_generation_arthemy_real.py +13 -15
  199. intentkit/skills/heurist/image_generation_braindance.py +13 -15
  200. intentkit/skills/heurist/image_generation_cyber_realistic_xl.py +13 -15
  201. intentkit/skills/heurist/image_generation_flux_1_dev.py +13 -15
  202. intentkit/skills/heurist/image_generation_sdxl.py +13 -15
  203. intentkit/skills/heurist/schema.json +2 -2
  204. intentkit/skills/http/__init__.py +4 -15
  205. intentkit/skills/http/base.py +1 -7
  206. intentkit/skills/http/get.py +21 -16
  207. intentkit/skills/http/post.py +23 -18
  208. intentkit/skills/http/put.py +23 -18
  209. intentkit/skills/http/schema.json +4 -5
  210. intentkit/skills/lifi/__init__.py +8 -13
  211. intentkit/skills/lifi/base.py +3 -9
  212. intentkit/skills/lifi/schema.json +17 -8
  213. intentkit/skills/lifi/token_execute.py +150 -60
  214. intentkit/skills/lifi/token_quote.py +8 -10
  215. intentkit/skills/lifi/utils.py +104 -51
  216. intentkit/skills/moralis/__init__.py +6 -10
  217. intentkit/skills/moralis/api.py +6 -7
  218. intentkit/skills/moralis/base.py +5 -10
  219. intentkit/skills/moralis/fetch_chain_portfolio.py +10 -11
  220. intentkit/skills/moralis/fetch_nft_portfolio.py +22 -22
  221. intentkit/skills/moralis/fetch_solana_portfolio.py +11 -12
  222. intentkit/skills/moralis/fetch_wallet_portfolio.py +8 -9
  223. intentkit/skills/moralis/schema.json +7 -2
  224. intentkit/skills/morpho/__init__.py +52 -0
  225. intentkit/skills/morpho/base.py +11 -0
  226. intentkit/skills/morpho/morpho.svg +12 -0
  227. intentkit/skills/morpho/schema.json +73 -0
  228. intentkit/skills/nation/__init__.py +4 -9
  229. intentkit/skills/nation/base.py +5 -10
  230. intentkit/skills/nation/nft_check.py +3 -4
  231. intentkit/skills/nation/schema.json +4 -3
  232. intentkit/skills/onchain.py +30 -0
  233. intentkit/skills/openai/__init__.py +17 -18
  234. intentkit/skills/openai/base.py +10 -14
  235. intentkit/skills/openai/dalle_image_generation.py +4 -9
  236. intentkit/skills/openai/gpt_avatar_generator.py +102 -0
  237. intentkit/skills/openai/gpt_image_generation.py +5 -9
  238. intentkit/skills/openai/gpt_image_mini_generator.py +92 -0
  239. intentkit/skills/openai/gpt_image_to_image.py +5 -9
  240. intentkit/skills/openai/image_to_text.py +3 -7
  241. intentkit/skills/openai/schema.json +34 -3
  242. intentkit/skills/portfolio/__init__.py +11 -35
  243. intentkit/skills/portfolio/base.py +33 -19
  244. intentkit/skills/portfolio/schema.json +3 -5
  245. intentkit/skills/portfolio/token_balances.py +21 -21
  246. intentkit/skills/portfolio/wallet_approvals.py +17 -18
  247. intentkit/skills/portfolio/wallet_defi_positions.py +3 -3
  248. intentkit/skills/portfolio/wallet_history.py +31 -31
  249. intentkit/skills/portfolio/wallet_net_worth.py +13 -13
  250. intentkit/skills/portfolio/wallet_nfts.py +19 -19
  251. intentkit/skills/portfolio/wallet_profitability.py +18 -18
  252. intentkit/skills/portfolio/wallet_profitability_summary.py +5 -5
  253. intentkit/skills/portfolio/wallet_stats.py +3 -3
  254. intentkit/skills/portfolio/wallet_swaps.py +19 -19
  255. intentkit/skills/pyth/__init__.py +50 -0
  256. intentkit/skills/pyth/base.py +11 -0
  257. intentkit/skills/pyth/pyth.svg +6 -0
  258. intentkit/skills/pyth/schema.json +75 -0
  259. intentkit/skills/skills.toml +36 -0
  260. intentkit/skills/slack/__init__.py +5 -17
  261. intentkit/skills/slack/base.py +3 -9
  262. intentkit/skills/slack/get_channel.py +8 -8
  263. intentkit/skills/slack/get_message.py +9 -9
  264. intentkit/skills/slack/schedule_message.py +5 -5
  265. intentkit/skills/slack/schema.json +2 -2
  266. intentkit/skills/slack/send_message.py +3 -5
  267. intentkit/skills/supabase/__init__.py +7 -23
  268. intentkit/skills/supabase/base.py +1 -7
  269. intentkit/skills/supabase/delete_data.py +4 -4
  270. intentkit/skills/supabase/fetch_data.py +12 -12
  271. intentkit/skills/supabase/insert_data.py +4 -4
  272. intentkit/skills/supabase/invoke_function.py +6 -6
  273. intentkit/skills/supabase/schema.json +2 -3
  274. intentkit/skills/supabase/update_data.py +6 -6
  275. intentkit/skills/supabase/upsert_data.py +4 -4
  276. intentkit/skills/superfluid/__init__.py +53 -0
  277. intentkit/skills/superfluid/base.py +11 -0
  278. intentkit/skills/superfluid/schema.json +89 -0
  279. intentkit/skills/superfluid/superfluid.svg +6 -0
  280. intentkit/skills/system/__init__.py +7 -24
  281. intentkit/skills/system/add_autonomous_task.py +10 -12
  282. intentkit/skills/system/delete_autonomous_task.py +2 -2
  283. intentkit/skills/system/edit_autonomous_task.py +14 -18
  284. intentkit/skills/system/list_autonomous_tasks.py +3 -5
  285. intentkit/skills/system/read_agent_api_key.py +6 -4
  286. intentkit/skills/system/regenerate_agent_api_key.py +6 -4
  287. intentkit/skills/system/schema.json +6 -8
  288. intentkit/skills/tavily/__init__.py +3 -12
  289. intentkit/skills/tavily/base.py +4 -9
  290. intentkit/skills/tavily/schema.json +3 -5
  291. intentkit/skills/tavily/tavily_extract.py +2 -4
  292. intentkit/skills/tavily/tavily_search.py +4 -6
  293. intentkit/skills/token/__init__.py +5 -10
  294. intentkit/skills/token/base.py +7 -11
  295. intentkit/skills/token/erc20_transfers.py +19 -19
  296. intentkit/skills/token/schema.json +3 -6
  297. intentkit/skills/token/token_analytics.py +3 -3
  298. intentkit/skills/token/token_price.py +13 -13
  299. intentkit/skills/token/token_search.py +9 -9
  300. intentkit/skills/twitter/__init__.py +11 -35
  301. intentkit/skills/twitter/base.py +22 -34
  302. intentkit/skills/twitter/follow_user.py +2 -6
  303. intentkit/skills/twitter/get_mentions.py +5 -12
  304. intentkit/skills/twitter/get_timeline.py +4 -12
  305. intentkit/skills/twitter/get_user_by_username.py +2 -6
  306. intentkit/skills/twitter/get_user_tweets.py +5 -13
  307. intentkit/skills/twitter/like_tweet.py +2 -6
  308. intentkit/skills/twitter/post_tweet.py +6 -9
  309. intentkit/skills/twitter/reply_tweet.py +6 -9
  310. intentkit/skills/twitter/retweet.py +2 -6
  311. intentkit/skills/twitter/schema.json +1 -0
  312. intentkit/skills/twitter/search_tweets.py +4 -12
  313. intentkit/skills/unrealspeech/__init__.py +2 -7
  314. intentkit/skills/unrealspeech/base.py +2 -8
  315. intentkit/skills/unrealspeech/schema.json +2 -5
  316. intentkit/skills/unrealspeech/text_to_speech.py +8 -8
  317. intentkit/skills/venice_audio/__init__.py +98 -106
  318. intentkit/skills/venice_audio/base.py +117 -121
  319. intentkit/skills/venice_audio/input.py +41 -41
  320. intentkit/skills/venice_audio/schema.json +151 -152
  321. intentkit/skills/venice_audio/venice_audio.py +38 -21
  322. intentkit/skills/venice_image/__init__.py +147 -154
  323. intentkit/skills/venice_image/api.py +138 -138
  324. intentkit/skills/venice_image/base.py +185 -192
  325. intentkit/skills/venice_image/config.py +33 -35
  326. intentkit/skills/venice_image/image_enhance/image_enhance.py +2 -3
  327. intentkit/skills/venice_image/image_enhance/image_enhance_base.py +21 -23
  328. intentkit/skills/venice_image/image_enhance/image_enhance_input.py +38 -40
  329. intentkit/skills/venice_image/image_generation/image_generation_base.py +11 -10
  330. intentkit/skills/venice_image/image_generation/image_generation_fluently_xl.py +26 -26
  331. intentkit/skills/venice_image/image_generation/image_generation_flux_dev.py +27 -27
  332. intentkit/skills/venice_image/image_generation/image_generation_flux_dev_uncensored.py +26 -26
  333. intentkit/skills/venice_image/image_generation/image_generation_input.py +158 -158
  334. intentkit/skills/venice_image/image_generation/image_generation_lustify_sdxl.py +26 -26
  335. intentkit/skills/venice_image/image_generation/image_generation_pony_realism.py +26 -26
  336. intentkit/skills/venice_image/image_generation/image_generation_stable_diffusion_3_5.py +28 -28
  337. intentkit/skills/venice_image/image_generation/image_generation_venice_sd35.py +28 -28
  338. intentkit/skills/venice_image/image_upscale/image_upscale.py +3 -3
  339. intentkit/skills/venice_image/image_upscale/image_upscale_base.py +21 -23
  340. intentkit/skills/venice_image/image_upscale/image_upscale_input.py +22 -22
  341. intentkit/skills/venice_image/image_vision/image_vision.py +2 -2
  342. intentkit/skills/venice_image/image_vision/image_vision_base.py +17 -17
  343. intentkit/skills/venice_image/image_vision/image_vision_input.py +9 -9
  344. intentkit/skills/venice_image/schema.json +267 -267
  345. intentkit/skills/venice_image/utils.py +77 -78
  346. intentkit/skills/web_scraper/__init__.py +5 -18
  347. intentkit/skills/web_scraper/base.py +21 -7
  348. intentkit/skills/web_scraper/document_indexer.py +7 -6
  349. intentkit/skills/web_scraper/schema.json +2 -6
  350. intentkit/skills/web_scraper/scrape_and_index.py +15 -15
  351. intentkit/skills/web_scraper/utils.py +62 -63
  352. intentkit/skills/web_scraper/website_indexer.py +17 -19
  353. intentkit/skills/weth/__init__.py +49 -0
  354. intentkit/skills/weth/base.py +11 -0
  355. intentkit/skills/weth/schema.json +58 -0
  356. intentkit/skills/weth/weth.svg +6 -0
  357. intentkit/skills/wow/__init__.py +51 -0
  358. intentkit/skills/wow/base.py +11 -0
  359. intentkit/skills/wow/schema.json +89 -0
  360. intentkit/skills/wow/wow.svg +7 -0
  361. intentkit/skills/x402/__init__.py +58 -0
  362. intentkit/skills/x402/base.py +99 -0
  363. intentkit/skills/x402/http_request.py +117 -0
  364. intentkit/skills/x402/schema.json +40 -0
  365. intentkit/skills/x402/x402.webp +0 -0
  366. intentkit/skills/xmtp/__init__.py +4 -15
  367. intentkit/skills/xmtp/base.py +5 -5
  368. intentkit/skills/xmtp/price.py +7 -6
  369. intentkit/skills/xmtp/schema.json +69 -71
  370. intentkit/skills/xmtp/swap.py +6 -8
  371. intentkit/skills/xmtp/transfer.py +4 -6
  372. intentkit/utils/__init__.py +4 -0
  373. intentkit/utils/chain.py +198 -96
  374. intentkit/utils/ens.py +135 -0
  375. intentkit/utils/error.py +5 -2
  376. intentkit/utils/logging.py +9 -11
  377. intentkit/utils/schema.py +100 -0
  378. intentkit/utils/slack_alert.py +8 -8
  379. intentkit/utils/tx.py +16 -8
  380. intentkit/uv.lock +3377 -0
  381. {intentkit-0.7.5.dev3.dist-info → intentkit-0.8.34.dev7.dist-info}/METADATA +13 -15
  382. intentkit-0.8.34.dev7.dist-info/RECORD +478 -0
  383. intentkit-0.8.34.dev7.dist-info/licenses/LICENSE +21 -0
  384. intentkit/core/node.py +0 -215
  385. intentkit/models/conversation.py +0 -286
  386. intentkit/models/generator.py +0 -347
  387. intentkit/skills/cdp/get_balance.py +0 -110
  388. intentkit/skills/cdp/swap.py +0 -121
  389. intentkit/skills/moralis/tests/__init__.py +0 -0
  390. intentkit/skills/moralis/tests/test_wallet.py +0 -511
  391. intentkit-0.7.5.dev3.dist-info/RECORD +0 -424
  392. {intentkit-0.7.5.dev3.dist-info/licenses → intentkit}/LICENSE +0 -0
  393. {intentkit-0.7.5.dev3.dist-info → intentkit-0.8.34.dev7.dist-info}/WHEEL +0 -0
@@ -1,5 +1,4 @@
1
1
  import logging
2
- from typing import Type
3
2
 
4
3
  from langchain_core.tools import ToolException
5
4
  from pydantic import BaseModel, Field
@@ -32,7 +31,7 @@ class TwitterRetweet(TwitterBaseTool):
32
31
 
33
32
  name: str = NAME
34
33
  description: str = PROMPT
35
- args_schema: Type[BaseModel] = TwitterRetweetInput
34
+ args_schema: type[BaseModel] = TwitterRetweetInput
36
35
 
37
36
  async def _arun(self, tweet_id: str, **kwargs):
38
37
  context = self.get_context()
@@ -40,16 +39,13 @@ class TwitterRetweet(TwitterBaseTool):
40
39
  skill_config = context.agent.skill_config(self.category)
41
40
  twitter = get_twitter_client(
42
41
  agent_id=context.agent_id,
43
- skill_store=self.skill_store,
44
42
  config=skill_config,
45
43
  )
46
44
  client = await twitter.get_client()
47
45
 
48
46
  # Check rate limit only when not using OAuth
49
47
  if not twitter.use_key:
50
- await self.check_rate_limit(
51
- context.agent_id, max_requests=5, interval=15
52
- )
48
+ await self.check_rate_limit(max_requests=5, interval=15)
53
49
 
54
50
  # Get authenticated user's ID
55
51
  user_id = twitter.self_id
@@ -5,6 +5,7 @@
5
5
  "description": "Integration with X API enabling social media interactions including retrieving posts, mentions, user information, and posting content with media support",
6
6
  "x-icon": "https://ai.service.crestal.dev/skills/twitter/twitter.png",
7
7
  "x-tags": [
8
+ "Communication",
8
9
  "Social"
9
10
  ],
10
11
  "properties": {
@@ -1,6 +1,5 @@
1
1
  import datetime
2
2
  import logging
3
- from typing import Type
4
3
 
5
4
  from pydantic import BaseModel, Field
6
5
 
@@ -33,7 +32,7 @@ class TwitterSearchTweets(TwitterBaseTool):
33
32
 
34
33
  name: str = NAME
35
34
  description: str = PROMPT
36
- args_schema: Type[BaseModel] = TwitterSearchTweetsInput
35
+ args_schema: type[BaseModel] = TwitterSearchTweetsInput
37
36
 
38
37
  async def _arun(self, query: str, **kwargs):
39
38
  context = self.get_context()
@@ -42,21 +41,16 @@ class TwitterSearchTweets(TwitterBaseTool):
42
41
  skill_config = context.agent.skill_config(self.category)
43
42
  twitter = get_twitter_client(
44
43
  agent_id=context.agent_id,
45
- skill_store=self.skill_store,
46
44
  config=skill_config,
47
45
  )
48
46
  client = await twitter.get_client()
49
47
 
50
48
  # Check rate limit only when not using OAuth
51
49
  if not twitter.use_key:
52
- await self.check_rate_limit(
53
- context.agent_id, max_requests=1, interval=15
54
- )
50
+ await self.check_rate_limit(max_requests=1, interval=15)
55
51
 
56
52
  # Get since_id from store to avoid duplicate results
57
- last = await self.skill_store.get_agent_skill_data(
58
- context.agent_id, self.name, query
59
- )
53
+ last = await self.get_agent_skill_data(query)
60
54
  last = last or {}
61
55
  since_id = last.get("since_id")
62
56
 
@@ -104,9 +98,7 @@ class TwitterSearchTweets(TwitterBaseTool):
104
98
  if tweets.get("meta") and tweets.get("meta").get("newest_id"):
105
99
  last["since_id"] = tweets["meta"]["newest_id"]
106
100
  last["timestamp"] = datetime.datetime.now().isoformat()
107
- await self.skill_store.save_agent_skill_data(
108
- context.agent_id, self.name, query, last
109
- )
101
+ await self.save_agent_skill_data(query, last)
110
102
 
111
103
  return tweets
112
104
 
@@ -1,6 +1,5 @@
1
1
  from typing import TypedDict
2
2
 
3
- from intentkit.abstracts.skill import SkillStoreABC
4
3
  from intentkit.skills.base import SkillConfig, SkillState
5
4
  from intentkit.skills.unrealspeech.base import UnrealSpeechBaseTool
6
5
  from intentkit.skills.unrealspeech.text_to_speech import TextToSpeech
@@ -23,7 +22,6 @@ class Config(SkillConfig):
23
22
  async def get_skills(
24
23
  config: "Config",
25
24
  is_private: bool,
26
- store: SkillStoreABC,
27
25
  **_,
28
26
  ) -> list[UnrealSpeechBaseTool]:
29
27
  """Get all UnrealSpeech tools."""
@@ -37,19 +35,16 @@ async def get_skills(
37
35
  available_skills.append(skill_name)
38
36
 
39
37
  # Get each skill using the cached getter
40
- return [get_unrealspeech_skill(name, store) for name in available_skills]
38
+ return [get_unrealspeech_skill(name) for name in available_skills]
41
39
 
42
40
 
43
41
  def get_unrealspeech_skill(
44
42
  name: str,
45
- store: SkillStoreABC,
46
43
  ) -> UnrealSpeechBaseTool:
47
44
  """Get an UnrealSpeech skill by name."""
48
45
  if name == "text_to_speech":
49
46
  if name not in _cache:
50
- _cache[name] = TextToSpeech(
51
- skill_store=store,
52
- )
47
+ _cache[name] = TextToSpeech()
53
48
  return _cache[name]
54
49
  else:
55
50
  raise ValueError(f"Unknown UnrealSpeech skill: {name}")
@@ -1,9 +1,6 @@
1
- from typing import Type
2
-
3
- from langchain.tools.base import ToolException
1
+ from langchain_core.tools.base import ToolException
4
2
  from pydantic import BaseModel, Field
5
3
 
6
- from intentkit.abstracts.skill import SkillStoreABC
7
4
  from intentkit.skills.base import IntentKitSkill
8
5
 
9
6
 
@@ -12,10 +9,7 @@ class UnrealSpeechBaseTool(IntentKitSkill):
12
9
 
13
10
  name: str = Field(description="The name of the tool")
14
11
  description: str = Field(description="A description of what the tool does")
15
- args_schema: Type[BaseModel]
16
- skill_store: SkillStoreABC = Field(
17
- description="The skill store for persisting data"
18
- )
12
+ args_schema: type[BaseModel]
19
13
 
20
14
  def get_api_key(self) -> str:
21
15
  context = self.get_context()
@@ -5,10 +5,7 @@
5
5
  "description": "Convert text to natural-sounding speech with various voices and customization options",
6
6
  "x-icon": "https://ai.service.crestal.dev/skills/unrealspeech/unrealspeech.jpg",
7
7
  "x-tags": [
8
- "Audio",
9
- "Speech",
10
- "Text-to-Speech",
11
- "Voice"
8
+ "Audio"
12
9
  ],
13
10
  "properties": {
14
11
  "enabled": {
@@ -97,4 +94,4 @@
97
94
  }
98
95
  },
99
96
  "additionalProperties": true
100
- }
97
+ }
@@ -1,6 +1,6 @@
1
1
  import logging
2
2
  import os
3
- from typing import Any, Dict, Literal, Optional, Type
3
+ from typing import Any, Literal
4
4
 
5
5
  import httpx
6
6
  from langchain_core.callbacks.manager import CallbackManagerForToolRun
@@ -31,7 +31,7 @@ class TextToSpeechInput(BaseModel):
31
31
  default=0.0,
32
32
  )
33
33
 
34
- timestamp_type: Optional[Literal["word", "sentence"]] = Field(
34
+ timestamp_type: Literal["word", "sentence"] | None = Field(
35
35
  description="The type of timestamps to include in the response. 'word' for word-level timestamps, 'sentence' for sentence-level, or None for no timestamps.",
36
36
  default="word",
37
37
  )
@@ -52,9 +52,9 @@ class TextToSpeech(UnrealSpeechBaseTool):
52
52
  "Returns URLs to the generated audio file and word-level timestamps.\n"
53
53
  "Provides various voice options and speech customization parameters."
54
54
  )
55
- args_schema: Type[BaseModel] = TextToSpeechInput
55
+ args_schema: type[BaseModel] = TextToSpeechInput
56
56
 
57
- def get_env_var(self, env_var_name: str) -> Optional[str]:
57
+ def get_env_var(self, env_var_name: str) -> str | None:
58
58
  """Helper method to get environment variables."""
59
59
  return os.environ.get(env_var_name)
60
60
 
@@ -64,11 +64,11 @@ class TextToSpeech(UnrealSpeechBaseTool):
64
64
  voice_id: str = "af_sarah",
65
65
  bitrate: str = "192k",
66
66
  speed: float = 0.0,
67
- timestamp_type: Optional[Literal["word", "sentence"]] = "word",
68
- config: Optional[Any] = None,
69
- run_manager: Optional[CallbackManagerForToolRun] = None,
67
+ timestamp_type: Literal["word", "sentence"] | None = "word",
68
+ config: Any | None = None,
69
+ run_manager: CallbackManagerForToolRun | None = None,
70
70
  **kwargs,
71
- ) -> Dict[str, Any]:
71
+ ) -> dict[str, Any]:
72
72
  """Run the tool to convert text to speech."""
73
73
 
74
74
  # Get the API key from context config if available
@@ -1,106 +1,98 @@
1
- import logging
2
- from typing import List, Literal, Optional, TypedDict
3
-
4
- from intentkit.abstracts.skill import SkillStoreABC
5
- from intentkit.skills.base import SkillConfig, SkillState
6
- from intentkit.skills.venice_audio.base import VeniceAudioBaseTool
7
- from intentkit.skills.venice_audio.venice_audio import VeniceAudioTool
8
-
9
- logger = logging.getLogger(__name__)
10
-
11
-
12
- _cache: dict[str, VeniceAudioBaseTool] = {}
13
-
14
- _SKILL_NAME_TO_CLASS_MAP = {
15
- "text_to_speech": VeniceAudioTool,
16
- # Add new mappings here: "skill_name": SkillClassName
17
- }
18
-
19
-
20
- class SkillStates(TypedDict):
21
- text_to_speech: SkillState
22
-
23
-
24
- class Config(SkillConfig):
25
- enabled: bool
26
- voice_model: Literal["af_heart", "bm_lewis", "custom"]
27
- states: SkillStates # type: ignore
28
- api_key_provider: Optional[Literal["agent_owner"]]
29
-
30
- # conditionally required
31
- api_key: Optional[str]
32
- voice_model_custom: Optional[list[str]]
33
-
34
- # optional
35
- rate_limit_number: Optional[int]
36
- rate_limit_minutes: Optional[int]
37
-
38
-
39
- async def get_skills(
40
- config: "Config",
41
- is_private: bool,
42
- store: SkillStoreABC,
43
- **_, # Allow for extra arguments if the loader passes them
44
- ) -> list[VeniceAudioBaseTool]:
45
- """
46
- Factory function to create and return Venice Audio skill tools.
47
-
48
- Args:
49
- config: The configuration dictionary for the Venice Audio skill.
50
- skill_store: The skill store instance.
51
- agent_id: The ID of the agent requesting the skills.
52
-
53
- Returns:
54
- A list of VeniceAudioBaseTool instances for the Venice Audio skill.
55
- """
56
- # Check if the entire category is disabled first
57
- if not config.get("enabled", False):
58
- return []
59
-
60
- available_skills: List[VeniceAudioBaseTool] = []
61
- skill_states = config.get("states", {})
62
-
63
- # Iterate through all known skills defined in the map
64
- for skill_name in _SKILL_NAME_TO_CLASS_MAP:
65
- state = skill_states.get(
66
- skill_name, "disabled"
67
- ) # Default to disabled if not in config
68
-
69
- if state == "disabled":
70
- continue
71
- elif state == "public" or (state == "private" and is_private):
72
- # If enabled, get the skill instance using the factory function
73
- skill_instance = get_venice_audio_skill(skill_name, store)
74
- if skill_instance:
75
- available_skills.append(skill_instance)
76
- else:
77
- # This case should ideally not happen if the map is correct
78
- logger.warning(f"Could not instantiate known skill: {skill_name}")
79
-
80
- return available_skills
81
-
82
-
83
- def get_venice_audio_skill(
84
- name: str,
85
- store: SkillStoreABC,
86
- ) -> Optional[VeniceAudioBaseTool]:
87
- """
88
- Factory function to get a cached Venice Audio skill instance by name.
89
-
90
- Args:
91
- name: The name of voice model.
92
- store: The skill store, passed to the skill constructor.
93
-
94
- Returns:
95
- The requested Venice Audio skill instance, or None if the name is unknown.
96
- """
97
-
98
- # Return from cache immediately if already exists
99
- if name in _cache:
100
- return _cache[name]
101
-
102
- # Cache and return the newly created instance
103
- _cache[name] = VeniceAudioTool(
104
- skill_store=store,
105
- )
106
- return _cache[name]
1
+ import logging
2
+ from typing import Literal, TypedDict
3
+
4
+ from intentkit.skills.base import SkillConfig, SkillState
5
+ from intentkit.skills.venice_audio.base import VeniceAudioBaseTool
6
+ from intentkit.skills.venice_audio.venice_audio import VeniceAudioTool
7
+
8
+ logger = logging.getLogger(__name__)
9
+
10
+ _cache: dict[str, VeniceAudioBaseTool] = {}
11
+
12
+ _SKILL_NAME_TO_CLASS_MAP = {
13
+ "text_to_speech": VeniceAudioTool,
14
+ # Add new mappings here: "skill_name": SkillClassName
15
+ }
16
+
17
+
18
+ class SkillStates(TypedDict):
19
+ text_to_speech: SkillState
20
+
21
+
22
+ class Config(SkillConfig):
23
+ enabled: bool
24
+ voice_model: Literal["af_heart", "bm_lewis", "custom"]
25
+ states: SkillStates # type: ignore
26
+ api_key_provider: Literal["agent_owner"] | None
27
+
28
+ # conditionally required
29
+ api_key: str | None
30
+ voice_model_custom: list[str] | None
31
+
32
+ # optional
33
+ rate_limit_number: int | None
34
+ rate_limit_minutes: int | None
35
+
36
+
37
+ async def get_skills(
38
+ config: "Config",
39
+ is_private: bool,
40
+ **_, # Allow for extra arguments if the loader passes them
41
+ ) -> list[VeniceAudioBaseTool]:
42
+ """
43
+ Factory function to create and return Venice Audio skill tools.
44
+
45
+ Args:
46
+ config: The configuration dictionary for the Venice Audio skill.
47
+ agent_id: The ID of the agent requesting the skills.
48
+
49
+ Returns:
50
+ A list of VeniceAudioBaseTool instances for the Venice Audio skill.
51
+ """
52
+ # Check if the entire category is disabled first
53
+ if not config.get("enabled", False):
54
+ return []
55
+
56
+ available_skills: list[VeniceAudioBaseTool] = []
57
+ skill_states = config.get("states", {})
58
+
59
+ # Iterate through all known skills defined in the map
60
+ for skill_name in _SKILL_NAME_TO_CLASS_MAP:
61
+ state = skill_states.get(
62
+ skill_name, "disabled"
63
+ ) # Default to disabled if not in config
64
+
65
+ if state == "disabled":
66
+ continue
67
+ elif state == "public" or (state == "private" and is_private):
68
+ # If enabled, get the skill instance using the factory function
69
+ skill_instance = get_venice_audio_skill(skill_name)
70
+ if skill_instance:
71
+ available_skills.append(skill_instance)
72
+ else:
73
+ # This case should ideally not happen if the map is correct
74
+ logger.warning(f"Could not instantiate known skill: {skill_name}")
75
+
76
+ return available_skills
77
+
78
+
79
+ def get_venice_audio_skill(
80
+ name: str,
81
+ ) -> VeniceAudioBaseTool | None:
82
+ """
83
+ Factory function to get a cached Venice Audio skill instance by name.
84
+
85
+ Args:
86
+ name: The name of voice model.
87
+
88
+ Returns:
89
+ The requested Venice Audio skill instance, or None if the name is unknown.
90
+ """
91
+
92
+ # Return from cache immediately if already exists
93
+ if name in _cache:
94
+ return _cache[name]
95
+
96
+ # Cache and return the newly created instance
97
+ _cache[name] = VeniceAudioTool()
98
+ return _cache[name]