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,121 +1,117 @@
1
- import logging
2
- from typing import Dict, List, Optional, Tuple, Type
3
-
4
- from langchain.tools.base import ToolException
5
- from pydantic import BaseModel, Field
6
-
7
- from intentkit.abstracts.skill import SkillStoreABC
8
- from intentkit.skills.base import IntentKitSkill
9
-
10
- logger = logging.getLogger(__name__)
11
-
12
-
13
- class VeniceAudioBaseTool(IntentKitSkill):
14
- """Base class for Venice Audio tools."""
15
-
16
- name: str = Field(default="venice_base_tool", description="The name of the tool")
17
- description: str = Field(description="A description of what the tool does")
18
- args_schema: Type[BaseModel] # type: ignore
19
- skill_store: SkillStoreABC = Field(
20
- description="The skill store for persisting data"
21
- )
22
-
23
- @property
24
- def category(self) -> str:
25
- return "venice_audio"
26
-
27
- def validate_voice_model(
28
- self, context, voice_model: str
29
- ) -> Tuple[bool, Optional[Dict[str, object]]]:
30
- config = context.config
31
-
32
- selected_model = config.get("voice_model")
33
- custom_models = config.get("voice_model_custom", [])
34
-
35
- allowed_voice_models: List[str] = []
36
-
37
- if selected_model == "custom":
38
- allowed_voice_models = custom_models or []
39
- else:
40
- allowed_voice_models = [selected_model] if selected_model else []
41
-
42
- if voice_model not in allowed_voice_models:
43
- return False, {
44
- "error": f'"{voice_model}" is not allowed',
45
- "allowed": allowed_voice_models,
46
- "suggestion": "please try again with allowed voice model",
47
- }
48
-
49
- return True, None
50
-
51
- def get_api_key(self) -> str:
52
- """
53
- Retrieves the Venice AI API key based on the api_key_provider setting.
54
-
55
- Returns:
56
- The API key if found.
57
-
58
- Raises:
59
- ToolException: If the API key is not found or provider is invalid.
60
- """
61
- try:
62
- context = self.get_context()
63
- skill_config = context.agent.skill_config(self.category)
64
- api_key_provider = skill_config.get("api_key_provider")
65
- if api_key_provider == "agent_owner":
66
- agent_api_key = skill_config.get("api_key")
67
- if agent_api_key:
68
- logger.debug(
69
- f"Using agent-specific Venice API key for skill {self.name} in category {self.category}"
70
- )
71
- return agent_api_key
72
- raise ToolException(
73
- f"No agent-owned Venice API key found for skill '{self.name}' in category '{self.category}'."
74
- )
75
-
76
- elif api_key_provider == "platform":
77
- system_api_key = self.skill_store.get_system_config("venice_api_key")
78
- if system_api_key:
79
- logger.debug(
80
- f"Using system Venice API key for skill {self.name} in category {self.category}"
81
- )
82
- return system_api_key
83
- raise ToolException(
84
- f"No platform-hosted Venice API key found for skill '{self.name}' in category '{self.category}'."
85
- )
86
-
87
- else:
88
- raise ToolException(
89
- f"Invalid API key provider '{api_key_provider}' for skill '{self.name}'"
90
- )
91
-
92
- except Exception as e:
93
- raise ToolException(f"Failed to retrieve Venice API key: {str(e)}") from e
94
-
95
- async def apply_rate_limit(self, context) -> None:
96
- """
97
- Applies rate limiting ONLY if specified in the agent's config ('skill_config').
98
- Checks for 'rate_limit_number' and 'rate_limit_minutes'.
99
- If not configured, NO rate limiting is applied.
100
- Raises ConnectionAbortedError if the configured limit is exceeded.
101
- """
102
- skill_config = context.agent.skill_config(self.category)
103
- user_id = context.agent.id
104
-
105
- # Get agent-specific limits safely
106
- limit_num = skill_config.get("rate_limit_number")
107
- limit_min = skill_config.get("rate_limit_minutes")
108
-
109
- # Apply limit ONLY if both values are present and valid (truthy check handles None and 0)
110
- if limit_num and limit_min:
111
- limit_source = "Agent"
112
- logger.debug(
113
- f"Applying {limit_source} rate limit ({limit_num}/{limit_min} min) for user {user_id} on {self.name}"
114
- )
115
- if user_id:
116
- await self.user_rate_limit_by_category(user_id, limit_num, limit_min)
117
- else:
118
- # No valid agent configuration found, so do nothing.
119
- logger.debug(
120
- f"No agent rate limits configured for category '{self.category}'. Skipping rate limit for user {user_id}."
121
- )
1
+ import logging
2
+
3
+ from langchain_core.tools.base import ToolException
4
+ from pydantic import BaseModel, Field
5
+
6
+ from intentkit.config.config import config
7
+ from intentkit.skills.base import IntentKitSkill
8
+
9
+ logger = logging.getLogger(__name__)
10
+
11
+
12
+ class VeniceAudioBaseTool(IntentKitSkill):
13
+ """Base class for Venice Audio tools."""
14
+
15
+ name: str = Field(default="venice_base_tool", description="The name of the tool")
16
+ description: str = Field(description="A description of what the tool does")
17
+ args_schema: type[BaseModel] # type: ignore
18
+
19
+ @property
20
+ def category(self) -> str:
21
+ return "venice_audio"
22
+
23
+ def validate_voice_model(
24
+ self, context, voice_model: str
25
+ ) -> tuple[bool, dict[str, object] | None]:
26
+ config = context.config
27
+
28
+ selected_model = config.get("voice_model")
29
+ custom_models = config.get("voice_model_custom", [])
30
+
31
+ allowed_voice_models: list[str] = []
32
+
33
+ if selected_model == "custom":
34
+ allowed_voice_models = custom_models or []
35
+ else:
36
+ allowed_voice_models = [selected_model] if selected_model else []
37
+
38
+ if voice_model not in allowed_voice_models:
39
+ return False, {
40
+ "error": f'"{voice_model}" is not allowed',
41
+ "allowed": allowed_voice_models,
42
+ "suggestion": "please try again with allowed voice model",
43
+ }
44
+
45
+ return True, None
46
+
47
+ def get_api_key(self) -> str:
48
+ """
49
+ Retrieves the Venice AI API key based on the api_key_provider setting.
50
+
51
+ Returns:
52
+ The API key if found.
53
+
54
+ Raises:
55
+ ToolException: If the API key is not found or provider is invalid.
56
+ """
57
+ try:
58
+ context = self.get_context()
59
+ skill_config = context.agent.skill_config(self.category)
60
+ api_key_provider = skill_config.get("api_key_provider")
61
+ if api_key_provider == "agent_owner":
62
+ agent_api_key = skill_config.get("api_key")
63
+ if agent_api_key:
64
+ logger.debug(
65
+ f"Using agent-specific Venice API key for skill {self.name} in category {self.category}"
66
+ )
67
+ return agent_api_key
68
+ raise ToolException(
69
+ f"No agent-owned Venice API key found for skill '{self.name}' in category '{self.category}'."
70
+ )
71
+
72
+ elif api_key_provider == "platform":
73
+ system_api_key = config.venice_api_key
74
+ if system_api_key:
75
+ logger.debug(
76
+ f"Using system Venice API key for skill {self.name} in category {self.category}"
77
+ )
78
+ return system_api_key
79
+ raise ToolException(
80
+ f"No platform-hosted Venice API key found for skill '{self.name}' in category '{self.category}'."
81
+ )
82
+
83
+ else:
84
+ raise ToolException(
85
+ f"Invalid API key provider '{api_key_provider}' for skill '{self.name}'"
86
+ )
87
+
88
+ except Exception as e:
89
+ raise ToolException(f"Failed to retrieve Venice API key: {str(e)}") from e
90
+
91
+ async def apply_rate_limit(self, context) -> None:
92
+ """
93
+ Applies rate limiting ONLY if specified in the agent's config ('skill_config').
94
+ Checks for 'rate_limit_number' and 'rate_limit_minutes'.
95
+ If not configured, NO rate limiting is applied.
96
+ Raises ConnectionAbortedError if the configured limit is exceeded.
97
+ """
98
+ skill_config = context.agent.skill_config(self.category)
99
+ user_id = context.agent.id
100
+
101
+ # Get agent-specific limits safely
102
+ limit_num = skill_config.get("rate_limit_number")
103
+ limit_min = skill_config.get("rate_limit_minutes")
104
+
105
+ # Apply limit ONLY if both values are present and valid (truthy check handles None and 0)
106
+ if limit_num and limit_min:
107
+ limit_source = "Agent"
108
+ logger.debug(
109
+ f"Applying {limit_source} rate limit ({limit_num}/{limit_min} min) for user {user_id} on {self.name}"
110
+ )
111
+ if user_id:
112
+ await self.user_rate_limit_by_category(limit_num, limit_min * 60)
113
+ else:
114
+ # No valid agent configuration found, so do nothing.
115
+ logger.debug(
116
+ f"No agent rate limits configured for category '{self.category}'. Skipping rate limit for user {user_id}."
117
+ )
@@ -1,41 +1,41 @@
1
- from typing import Literal, Optional
2
-
3
- from pydantic import BaseModel, Field
4
-
5
- # Define the allowed format literals based on the API documentation
6
- AllowedAudioFormat = Literal["mp3", "opus", "aac", "flac", "wav", "pcm"]
7
-
8
-
9
- class VeniceAudioInput(BaseModel):
10
- """
11
- Input schema for Venice AI Text-to-Speech (/audio/speech endpoint).
12
- Defines parameters controllable by the user when invoking the tool.
13
- """
14
-
15
- input: str = Field(
16
- ..., # Ellipsis (...) indicates this field is required
17
- description="The text to generate audio for. Maximum length is 4096 characters.",
18
- min_length=1, # As per API docs: Required string length: 1
19
- max_length=4096, # As per API docs: The maximum length is 4096 characters.
20
- )
21
-
22
- voice_model: str = Field(
23
- description="voice model to used to generate voice from text_to_speech tool."
24
- )
25
-
26
- speed: Optional[float] = Field(
27
- default=1.0, # As per API docs: default: 1 (using float for consistency)
28
- description="The speed of the generated audio. 1.0 is normal speed. Allowed range: 0.25 to 4.0.",
29
- ge=0.25, # As per API docs: Required range: 0.25 <= x
30
- le=4.0, # As per API docs: Required range: x <= 4
31
- )
32
-
33
- response_format: Optional[AllowedAudioFormat] = Field(
34
- default="mp3", # As per API docs: default: mp3
35
- description="The desired audio format for the output file.",
36
- )
37
-
38
- # --- Note on other API parameters ---
39
- # 'model': Currently hardcoded to 'tts-kokoro' in VeniceAudioBaseTool._arun. Could be added here if needed.
40
- # 'voice': Handled by the 'voice_model' attribute of the specific VeniceAudioBaseTool instance. Not typically set via input schema.
41
- # 'streaming': Currently hardcoded to False in VeniceAudioBaseTool._arun. Could be added here if streaming support is implemented.
1
+ from typing import Literal
2
+
3
+ from pydantic import BaseModel, Field
4
+
5
+ # Define the allowed format literals based on the API documentation
6
+ AllowedAudioFormat = Literal["mp3", "opus", "aac", "flac", "wav", "pcm"]
7
+
8
+
9
+ class VeniceAudioInput(BaseModel):
10
+ """
11
+ Input schema for Venice AI Text-to-Speech (/audio/speech endpoint).
12
+ Defines parameters controllable by the user when invoking the tool.
13
+ """
14
+
15
+ voice_input: str = Field(
16
+ ..., # Ellipsis (...) indicates this field is required
17
+ description="The text to generate audio for. Maximum length is 4096 characters.",
18
+ min_length=1, # As per API docs: Required string length: 1
19
+ max_length=4096, # As per API docs: The maximum length is 4096 characters.
20
+ )
21
+
22
+ voice_model: str = Field(
23
+ description="voice model to used to generate voice from text_to_speech tool."
24
+ )
25
+
26
+ speed: float | None = Field(
27
+ default=1.0, # As per API docs: default: 1 (using float for consistency)
28
+ description="The speed of the generated audio. 1.0 is normal speed. Allowed range: 0.25 to 4.0.",
29
+ ge=0.25, # As per API docs: Required range: 0.25 <= x
30
+ le=4.0, # As per API docs: Required range: x <= 4
31
+ )
32
+
33
+ response_format: AllowedAudioFormat | None = Field(
34
+ default="mp3", # As per API docs: default: mp3
35
+ description="The desired audio format for the output file.",
36
+ )
37
+
38
+ # --- Note on other API parameters ---
39
+ # 'model': Currently hardcoded to 'tts-kokoro' in VeniceAudioBaseTool._arun. Could be added here if needed.
40
+ # 'voice': Handled by the 'voice_model' attribute of the specific VeniceAudioBaseTool instance. Not typically set via input schema.
41
+ # 'streaming': Currently hardcoded to False in VeniceAudioBaseTool._arun. Could be added here if streaming support is implemented.
@@ -1,152 +1,151 @@
1
- {
2
- "$schema": "http://json-schema.org/draft-07/schema#",
3
- "title": "Venice Audio Skills",
4
- "x-icon": "https://ai.service.crestal.dev/skills/venice_audio/venice_audio.jpg",
5
- "description": "Configuration for the Venice Audio skill.",
6
- "type": "object",
7
- "x-tags": [
8
- "AI",
9
- "Audio",
10
- "Text to Speech"
11
- ],
12
- "properties": {
13
- "enabled": {
14
- "type": "boolean",
15
- "title": "Enabled",
16
- "description": "Enable or disable the Venice Audio skill.",
17
- "default": false
18
- },
19
- "voice_model": {
20
- "type": "string",
21
- "title": "Voice Model",
22
- "x-link": "[Listen Voice Example](https://huggingface.co/spaces/hexgrad/Kokoro-TTS)",
23
- "enum": [
24
- "af_heart",
25
- "bm_lewis",
26
- "custom"
27
- ],
28
- "x-enum-title": [
29
- "af_heart (default female)",
30
- "bm_lewis (default male)",
31
- "Custom"
32
- ],
33
- "description": "Text to speech tool",
34
- "default": "af_heart"
35
- },
36
- "states": {
37
- "type": "object",
38
- "title": "Skill States",
39
- "description": "Enable/disable specific voice models. Only enable one if you want a consistent characteristic for your agent. See docs for voice details and quality grades.",
40
- "properties": {
41
- "text_to_speech": {
42
- "type": "string",
43
- "title": "Text to Speech",
44
- "enum": [
45
- "disabled",
46
- "public",
47
- "private"
48
- ],
49
- "x-enum-title": [
50
- "Disabled",
51
- "Agent Owner + All Users",
52
- "Agent Owner Only"
53
- ],
54
- "description": "Text to speech tool",
55
- "default": "disabled"
56
- }
57
- }
58
- },
59
- "api_key_provider": {
60
- "type": "string",
61
- "title": "API Key Provider",
62
- "description": "Provider of the API key",
63
- "enum": [
64
- "agent_owner"
65
- ],
66
- "x-enum-title": [
67
- "Owner Provided"
68
- ],
69
- "default": "agent_owner"
70
- }
71
- },
72
- "required": [
73
- "states",
74
- "enabled"
75
- ],
76
- "allOf": [
77
- {
78
- "if": {
79
- "properties": {
80
- "voice_model": {
81
- "const": "custom"
82
- }
83
- }
84
- },
85
- "then": {
86
- "properties": {
87
- "voice_model_custom": {
88
- "type": "array",
89
- "items": {
90
- "type": "string"
91
- },
92
- "title": "Voice Model (Custom)",
93
- "x-link": "[Supported Voice Model](https://docs.venice.ai/api-reference/endpoint/audio/speech#body-voice)",
94
- "description": "You can add one or more custom voice models.",
95
- "default": [
96
- "af_heart",
97
- "bm_lewis"
98
- ]
99
- }
100
- },
101
- "required": [
102
- "voice_model_custom"
103
- ]
104
- }
105
- },
106
- {
107
- "if": {
108
- "allOf": [
109
- {
110
- "properties": {
111
- "enabled": {
112
- "const": true
113
- }
114
- }
115
- },
116
- {
117
- "properties": {
118
- "api_key_provider": {
119
- "const": "agent_owner"
120
- }
121
- }
122
- }
123
- ]
124
- },
125
- "then": {
126
- "properties": {
127
- "api_key": {
128
- "type": "string",
129
- "title": "Venice API Key",
130
- "x-link": "[Get your API key](https://venice.ai/)",
131
- "x-sensitive": true,
132
- "description": "API Key for authenticating with the Venice AI API."
133
- },
134
- "rate_limit_number": {
135
- "type": "integer",
136
- "title": "Rate Limit Number",
137
- "description": "Number of requests allowed per time window."
138
- },
139
- "rate_limit_minutes": {
140
- "type": "integer",
141
- "title": "Rate Limit Minutes",
142
- "description": "Time window in minutes for rate limiting."
143
- }
144
- },
145
- "required": [
146
- "api_key"
147
- ]
148
- }
149
- }
150
- ],
151
- "additionalProperties": true
152
- }
1
+ {
2
+ "$schema": "http://json-schema.org/draft-07/schema#",
3
+ "title": "Venice Audio Skills",
4
+ "x-icon": "https://ai.service.crestal.dev/skills/venice_audio/venice_audio.jpg",
5
+ "description": "Configuration for the Venice Audio skill.",
6
+ "type": "object",
7
+ "x-tags": [
8
+ "AI",
9
+ "Audio"
10
+ ],
11
+ "properties": {
12
+ "enabled": {
13
+ "type": "boolean",
14
+ "title": "Enabled",
15
+ "description": "Enable or disable the Venice Audio skill.",
16
+ "default": false
17
+ },
18
+ "voice_model": {
19
+ "type": "string",
20
+ "title": "Voice Model",
21
+ "x-link": "[Listen Voice Example](https://huggingface.co/spaces/hexgrad/Kokoro-TTS)",
22
+ "enum": [
23
+ "af_heart",
24
+ "bm_lewis",
25
+ "custom"
26
+ ],
27
+ "x-enum-title": [
28
+ "af_heart (default female)",
29
+ "bm_lewis (default male)",
30
+ "Custom"
31
+ ],
32
+ "description": "Text to speech tool",
33
+ "default": "af_heart"
34
+ },
35
+ "states": {
36
+ "type": "object",
37
+ "title": "Skill States",
38
+ "description": "Enable/disable specific voice models. Only enable one if you want a consistent characteristic for your agent. See docs for voice details and quality grades.",
39
+ "properties": {
40
+ "text_to_speech": {
41
+ "type": "string",
42
+ "title": "Text to Speech",
43
+ "enum": [
44
+ "disabled",
45
+ "public",
46
+ "private"
47
+ ],
48
+ "x-enum-title": [
49
+ "Disabled",
50
+ "Agent Owner + All Users",
51
+ "Agent Owner Only"
52
+ ],
53
+ "description": "Text to speech tool",
54
+ "default": "disabled"
55
+ }
56
+ }
57
+ },
58
+ "api_key_provider": {
59
+ "type": "string",
60
+ "title": "API Key Provider",
61
+ "description": "Provider of the API key",
62
+ "enum": [
63
+ "agent_owner"
64
+ ],
65
+ "x-enum-title": [
66
+ "Owner Provided"
67
+ ],
68
+ "default": "agent_owner"
69
+ }
70
+ },
71
+ "required": [
72
+ "states",
73
+ "enabled"
74
+ ],
75
+ "allOf": [
76
+ {
77
+ "if": {
78
+ "properties": {
79
+ "voice_model": {
80
+ "const": "custom"
81
+ }
82
+ }
83
+ },
84
+ "then": {
85
+ "properties": {
86
+ "voice_model_custom": {
87
+ "type": "array",
88
+ "items": {
89
+ "type": "string"
90
+ },
91
+ "title": "Voice Model (Custom)",
92
+ "x-link": "[Supported Voice Model](https://docs.venice.ai/api-reference/endpoint/audio/speech#body-voice)",
93
+ "description": "You can add one or more custom voice models.",
94
+ "default": [
95
+ "af_heart",
96
+ "bm_lewis"
97
+ ]
98
+ }
99
+ },
100
+ "required": [
101
+ "voice_model_custom"
102
+ ]
103
+ }
104
+ },
105
+ {
106
+ "if": {
107
+ "allOf": [
108
+ {
109
+ "properties": {
110
+ "enabled": {
111
+ "const": true
112
+ }
113
+ }
114
+ },
115
+ {
116
+ "properties": {
117
+ "api_key_provider": {
118
+ "const": "agent_owner"
119
+ }
120
+ }
121
+ }
122
+ ]
123
+ },
124
+ "then": {
125
+ "properties": {
126
+ "api_key": {
127
+ "type": "string",
128
+ "title": "Venice API Key",
129
+ "x-link": "[Get your API key](https://venice.ai/)",
130
+ "x-sensitive": true,
131
+ "description": "API Key for authenticating with the Venice AI API."
132
+ },
133
+ "rate_limit_number": {
134
+ "type": "integer",
135
+ "title": "Rate Limit Number",
136
+ "description": "Number of requests allowed per time window."
137
+ },
138
+ "rate_limit_minutes": {
139
+ "type": "integer",
140
+ "title": "Rate Limit Minutes",
141
+ "description": "Time window in minutes for rate limiting."
142
+ }
143
+ },
144
+ "required": [
145
+ "api_key"
146
+ ]
147
+ }
148
+ }
149
+ ],
150
+ "additionalProperties": true
151
+ }