intentkit 0.8.6.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.
- intentkit/__init__.py +1 -1
- intentkit/abstracts/agent.py +4 -5
- intentkit/abstracts/engine.py +5 -5
- intentkit/abstracts/graph.py +10 -5
- intentkit/abstracts/skill.py +6 -144
- intentkit/abstracts/twitter.py +4 -5
- intentkit/clients/__init__.py +3 -2
- intentkit/clients/cdp.py +53 -92
- intentkit/clients/twitter.py +56 -57
- intentkit/clients/web3.py +1 -3
- intentkit/config/config.py +5 -0
- intentkit/core/agent.py +16 -388
- intentkit/core/asset.py +64 -18
- intentkit/core/client.py +1 -1
- intentkit/core/credit.py +19 -20
- intentkit/core/engine.py +26 -11
- intentkit/core/node.py +2 -1
- intentkit/core/prompt.py +53 -15
- intentkit/core/scheduler.py +9 -9
- intentkit/core/statistics.py +6 -7
- intentkit/models/agent.py +256 -176
- intentkit/models/agent_data.py +62 -36
- intentkit/models/agent_schema.json +6 -9
- intentkit/models/app_setting.py +6 -6
- intentkit/models/chat.py +28 -24
- intentkit/models/conversation.py +8 -8
- intentkit/models/credit.py +62 -64
- intentkit/models/db.py +8 -7
- intentkit/models/db_mig.py +2 -2
- intentkit/models/llm.csv +15 -12
- intentkit/models/llm.py +18 -16
- intentkit/models/redis.py +2 -3
- intentkit/models/skill.py +62 -66
- intentkit/models/skills.csv +30 -26
- intentkit/models/user.py +46 -21
- intentkit/skills/acolyt/__init__.py +2 -9
- intentkit/skills/acolyt/ask.py +3 -4
- intentkit/skills/acolyt/base.py +4 -9
- intentkit/skills/aixbt/__init__.py +2 -13
- intentkit/skills/aixbt/base.py +1 -7
- intentkit/skills/aixbt/projects.py +14 -15
- intentkit/skills/allora/__init__.py +2 -9
- intentkit/skills/allora/base.py +4 -9
- intentkit/skills/allora/price.py +3 -4
- intentkit/skills/base.py +175 -52
- intentkit/skills/basename/__init__.py +4 -8
- intentkit/skills/carv/__init__.py +115 -121
- intentkit/skills/carv/base.py +184 -185
- intentkit/skills/carv/fetch_news.py +3 -3
- intentkit/skills/carv/onchain_query.py +4 -4
- intentkit/skills/carv/token_info_and_price.py +5 -5
- intentkit/skills/casino/__init__.py +4 -15
- intentkit/skills/casino/base.py +1 -7
- intentkit/skills/casino/deck_draw.py +5 -8
- intentkit/skills/casino/deck_shuffle.py +6 -6
- intentkit/skills/casino/dice_roll.py +2 -4
- intentkit/skills/cdp/__init__.py +3 -10
- intentkit/skills/cdp/base.py +1 -7
- intentkit/skills/cdp/schema.json +1 -17
- intentkit/skills/chainlist/__init__.py +2 -7
- intentkit/skills/chainlist/base.py +1 -7
- intentkit/skills/chainlist/chain_lookup.py +18 -18
- intentkit/skills/common/__init__.py +2 -9
- intentkit/skills/common/base.py +1 -7
- intentkit/skills/common/current_time.py +1 -2
- intentkit/skills/cookiefun/__init__.py +6 -9
- intentkit/skills/cookiefun/base.py +2 -7
- intentkit/skills/cookiefun/get_account_details.py +7 -7
- intentkit/skills/cookiefun/get_account_feed.py +19 -19
- intentkit/skills/cookiefun/get_account_smart_followers.py +7 -7
- intentkit/skills/cookiefun/get_sectors.py +3 -3
- intentkit/skills/cookiefun/search_accounts.py +9 -9
- intentkit/skills/cryptocompare/__init__.py +7 -24
- intentkit/skills/cryptocompare/api.py +2 -3
- intentkit/skills/cryptocompare/base.py +10 -24
- intentkit/skills/cryptocompare/fetch_news.py +4 -5
- intentkit/skills/cryptocompare/fetch_price.py +6 -7
- intentkit/skills/cryptocompare/fetch_top_exchanges.py +4 -5
- intentkit/skills/cryptocompare/fetch_top_market_cap.py +4 -5
- intentkit/skills/cryptocompare/fetch_top_volume.py +4 -5
- intentkit/skills/cryptocompare/fetch_trading_signals.py +5 -6
- intentkit/skills/cryptopanic/__init__.py +7 -10
- intentkit/skills/cryptopanic/base.py +51 -55
- intentkit/skills/cryptopanic/fetch_crypto_news.py +4 -8
- intentkit/skills/cryptopanic/fetch_crypto_sentiment.py +5 -7
- intentkit/skills/dapplooker/__init__.py +2 -9
- intentkit/skills/dapplooker/base.py +4 -9
- intentkit/skills/dapplooker/dapplooker_token_data.py +7 -7
- intentkit/skills/defillama/__init__.py +24 -74
- intentkit/skills/defillama/api.py +6 -9
- intentkit/skills/defillama/base.py +8 -19
- intentkit/skills/defillama/coins/fetch_batch_historical_prices.py +8 -10
- intentkit/skills/defillama/coins/fetch_block.py +6 -8
- intentkit/skills/defillama/coins/fetch_current_prices.py +8 -10
- intentkit/skills/defillama/coins/fetch_first_price.py +7 -9
- intentkit/skills/defillama/coins/fetch_historical_prices.py +9 -11
- intentkit/skills/defillama/coins/fetch_price_chart.py +9 -11
- intentkit/skills/defillama/coins/fetch_price_percentage.py +7 -9
- intentkit/skills/defillama/config/chains.py +1 -3
- intentkit/skills/defillama/fees/fetch_fees_overview.py +24 -26
- intentkit/skills/defillama/stablecoins/fetch_stablecoin_chains.py +16 -18
- intentkit/skills/defillama/stablecoins/fetch_stablecoin_charts.py +8 -10
- intentkit/skills/defillama/stablecoins/fetch_stablecoin_prices.py +5 -7
- intentkit/skills/defillama/stablecoins/fetch_stablecoins.py +7 -9
- intentkit/skills/defillama/tests/api_integration.test.py +1 -1
- intentkit/skills/defillama/tvl/fetch_chain_historical_tvl.py +4 -6
- intentkit/skills/defillama/tvl/fetch_chains.py +9 -11
- intentkit/skills/defillama/tvl/fetch_historical_tvl.py +4 -6
- intentkit/skills/defillama/tvl/fetch_protocol.py +32 -38
- intentkit/skills/defillama/tvl/fetch_protocol_current_tvl.py +3 -5
- intentkit/skills/defillama/tvl/fetch_protocols.py +37 -45
- intentkit/skills/defillama/volumes/fetch_dex_overview.py +42 -48
- intentkit/skills/defillama/volumes/fetch_dex_summary.py +35 -37
- intentkit/skills/defillama/volumes/fetch_options_overview.py +24 -28
- intentkit/skills/defillama/yields/fetch_pool_chart.py +10 -12
- intentkit/skills/defillama/yields/fetch_pools.py +26 -30
- intentkit/skills/dexscreener/__init__.py +97 -102
- intentkit/skills/dexscreener/base.py +125 -130
- intentkit/skills/dexscreener/get_pair_info.py +4 -5
- intentkit/skills/dexscreener/get_token_pairs.py +4 -5
- intentkit/skills/dexscreener/get_tokens_info.py +7 -8
- intentkit/skills/dexscreener/model/search_token_response.py +80 -82
- intentkit/skills/dexscreener/search_token.py +182 -184
- intentkit/skills/dexscreener/utils.py +15 -14
- intentkit/skills/dune_analytics/__init__.py +7 -9
- intentkit/skills/dune_analytics/base.py +48 -52
- intentkit/skills/dune_analytics/fetch_kol_buys.py +5 -7
- intentkit/skills/dune_analytics/fetch_nation_metrics.py +6 -8
- intentkit/skills/elfa/__init__.py +5 -18
- intentkit/skills/elfa/base.py +10 -14
- intentkit/skills/elfa/mention.py +19 -21
- intentkit/skills/elfa/stats.py +4 -4
- intentkit/skills/elfa/tokens.py +12 -12
- intentkit/skills/elfa/utils.py +26 -28
- intentkit/skills/enso/__init__.py +11 -31
- intentkit/skills/enso/base.py +9 -15
- intentkit/skills/enso/best_yield.py +5 -7
- intentkit/skills/enso/networks.py +3 -9
- intentkit/skills/enso/prices.py +2 -4
- intentkit/skills/enso/route.py +6 -12
- intentkit/skills/enso/tokens.py +4 -16
- intentkit/skills/enso/wallet.py +6 -6
- intentkit/skills/erc20/__init__.py +5 -11
- intentkit/skills/erc721/__init__.py +5 -9
- intentkit/skills/firecrawl/__init__.py +5 -18
- intentkit/skills/firecrawl/base.py +4 -9
- intentkit/skills/firecrawl/clear.py +4 -8
- intentkit/skills/firecrawl/crawl.py +19 -19
- intentkit/skills/firecrawl/query.py +4 -3
- intentkit/skills/firecrawl/scrape.py +17 -22
- intentkit/skills/firecrawl/utils.py +50 -42
- intentkit/skills/github/__init__.py +2 -7
- intentkit/skills/github/base.py +1 -7
- intentkit/skills/github/github_search.py +1 -2
- intentkit/skills/heurist/__init__.py +8 -27
- intentkit/skills/heurist/base.py +4 -9
- intentkit/skills/heurist/image_generation_animagine_xl.py +12 -13
- intentkit/skills/heurist/image_generation_arthemy_comics.py +12 -13
- intentkit/skills/heurist/image_generation_arthemy_real.py +12 -13
- intentkit/skills/heurist/image_generation_braindance.py +12 -13
- intentkit/skills/heurist/image_generation_cyber_realistic_xl.py +12 -13
- intentkit/skills/heurist/image_generation_flux_1_dev.py +12 -13
- intentkit/skills/heurist/image_generation_sdxl.py +12 -13
- intentkit/skills/http/__init__.py +4 -15
- intentkit/skills/http/base.py +1 -7
- intentkit/skills/http/get.py +21 -16
- intentkit/skills/http/post.py +23 -18
- intentkit/skills/http/put.py +23 -18
- intentkit/skills/lifi/__init__.py +5 -10
- intentkit/skills/lifi/base.py +1 -7
- intentkit/skills/lifi/token_execute.py +14 -17
- intentkit/skills/lifi/token_quote.py +7 -9
- intentkit/skills/lifi/utils.py +16 -16
- intentkit/skills/moralis/__init__.py +6 -10
- intentkit/skills/moralis/api.py +6 -7
- intentkit/skills/moralis/base.py +5 -10
- intentkit/skills/moralis/fetch_chain_portfolio.py +10 -11
- intentkit/skills/moralis/fetch_nft_portfolio.py +22 -22
- intentkit/skills/moralis/fetch_solana_portfolio.py +11 -12
- intentkit/skills/moralis/fetch_wallet_portfolio.py +8 -9
- intentkit/skills/morpho/__init__.py +5 -9
- intentkit/skills/nation/__init__.py +4 -9
- intentkit/skills/nation/base.py +5 -10
- intentkit/skills/nation/nft_check.py +3 -4
- intentkit/skills/onchain.py +23 -0
- intentkit/skills/openai/__init__.py +17 -18
- intentkit/skills/openai/base.py +10 -14
- intentkit/skills/openai/dalle_image_generation.py +3 -8
- intentkit/skills/openai/gpt_avatar_generator.py +102 -0
- intentkit/skills/openai/gpt_image_generation.py +4 -8
- intentkit/skills/openai/gpt_image_mini_generator.py +91 -0
- intentkit/skills/openai/gpt_image_to_image.py +4 -8
- intentkit/skills/openai/image_to_text.py +3 -7
- intentkit/skills/openai/schema.json +32 -0
- intentkit/skills/portfolio/__init__.py +11 -35
- intentkit/skills/portfolio/base.py +33 -19
- intentkit/skills/portfolio/token_balances.py +21 -21
- intentkit/skills/portfolio/wallet_approvals.py +17 -18
- intentkit/skills/portfolio/wallet_defi_positions.py +3 -3
- intentkit/skills/portfolio/wallet_history.py +31 -31
- intentkit/skills/portfolio/wallet_net_worth.py +13 -13
- intentkit/skills/portfolio/wallet_nfts.py +19 -19
- intentkit/skills/portfolio/wallet_profitability.py +18 -18
- intentkit/skills/portfolio/wallet_profitability_summary.py +5 -5
- intentkit/skills/portfolio/wallet_stats.py +3 -3
- intentkit/skills/portfolio/wallet_swaps.py +19 -19
- intentkit/skills/pyth/__init__.py +4 -10
- intentkit/skills/skills.toml +4 -0
- intentkit/skills/slack/__init__.py +5 -17
- intentkit/skills/slack/base.py +3 -9
- intentkit/skills/slack/get_channel.py +8 -8
- intentkit/skills/slack/get_message.py +9 -9
- intentkit/skills/slack/schedule_message.py +5 -5
- intentkit/skills/slack/send_message.py +3 -5
- intentkit/skills/supabase/__init__.py +7 -23
- intentkit/skills/supabase/base.py +1 -7
- intentkit/skills/supabase/delete_data.py +4 -4
- intentkit/skills/supabase/fetch_data.py +12 -12
- intentkit/skills/supabase/insert_data.py +4 -4
- intentkit/skills/supabase/invoke_function.py +6 -6
- intentkit/skills/supabase/update_data.py +6 -6
- intentkit/skills/supabase/upsert_data.py +4 -4
- intentkit/skills/superfluid/__init__.py +5 -9
- intentkit/skills/system/__init__.py +7 -24
- intentkit/skills/system/add_autonomous_task.py +10 -12
- intentkit/skills/system/delete_autonomous_task.py +2 -2
- intentkit/skills/system/edit_autonomous_task.py +14 -18
- intentkit/skills/system/list_autonomous_tasks.py +3 -5
- intentkit/skills/system/read_agent_api_key.py +6 -4
- intentkit/skills/system/regenerate_agent_api_key.py +6 -4
- intentkit/skills/tavily/__init__.py +3 -12
- intentkit/skills/tavily/base.py +4 -9
- intentkit/skills/tavily/tavily_extract.py +2 -4
- intentkit/skills/tavily/tavily_search.py +4 -6
- intentkit/skills/token/__init__.py +5 -10
- intentkit/skills/token/base.py +7 -11
- intentkit/skills/token/erc20_transfers.py +19 -19
- intentkit/skills/token/token_analytics.py +3 -3
- intentkit/skills/token/token_price.py +13 -13
- intentkit/skills/token/token_search.py +9 -9
- intentkit/skills/twitter/__init__.py +11 -35
- intentkit/skills/twitter/base.py +22 -34
- intentkit/skills/twitter/follow_user.py +2 -6
- intentkit/skills/twitter/get_mentions.py +5 -12
- intentkit/skills/twitter/get_timeline.py +4 -12
- intentkit/skills/twitter/get_user_by_username.py +2 -6
- intentkit/skills/twitter/get_user_tweets.py +5 -13
- intentkit/skills/twitter/like_tweet.py +2 -6
- intentkit/skills/twitter/post_tweet.py +6 -9
- intentkit/skills/twitter/reply_tweet.py +6 -9
- intentkit/skills/twitter/retweet.py +2 -6
- intentkit/skills/twitter/search_tweets.py +4 -12
- intentkit/skills/unrealspeech/__init__.py +2 -7
- intentkit/skills/unrealspeech/base.py +2 -8
- intentkit/skills/unrealspeech/text_to_speech.py +8 -8
- intentkit/skills/venice_audio/__init__.py +98 -106
- intentkit/skills/venice_audio/base.py +117 -121
- intentkit/skills/venice_audio/input.py +41 -41
- intentkit/skills/venice_audio/venice_audio.py +7 -11
- intentkit/skills/venice_image/__init__.py +147 -154
- intentkit/skills/venice_image/api.py +138 -138
- intentkit/skills/venice_image/base.py +185 -192
- intentkit/skills/venice_image/config.py +33 -35
- intentkit/skills/venice_image/image_enhance/image_enhance.py +2 -3
- intentkit/skills/venice_image/image_enhance/image_enhance_base.py +21 -23
- intentkit/skills/venice_image/image_enhance/image_enhance_input.py +38 -40
- intentkit/skills/venice_image/image_generation/image_generation_base.py +9 -9
- intentkit/skills/venice_image/image_generation/image_generation_fluently_xl.py +26 -26
- intentkit/skills/venice_image/image_generation/image_generation_flux_dev.py +27 -27
- intentkit/skills/venice_image/image_generation/image_generation_flux_dev_uncensored.py +26 -26
- intentkit/skills/venice_image/image_generation/image_generation_input.py +158 -158
- intentkit/skills/venice_image/image_generation/image_generation_lustify_sdxl.py +26 -26
- intentkit/skills/venice_image/image_generation/image_generation_pony_realism.py +26 -26
- intentkit/skills/venice_image/image_generation/image_generation_stable_diffusion_3_5.py +28 -28
- intentkit/skills/venice_image/image_generation/image_generation_venice_sd35.py +28 -28
- intentkit/skills/venice_image/image_upscale/image_upscale.py +3 -3
- intentkit/skills/venice_image/image_upscale/image_upscale_base.py +21 -23
- intentkit/skills/venice_image/image_upscale/image_upscale_input.py +22 -22
- intentkit/skills/venice_image/image_vision/image_vision.py +2 -2
- intentkit/skills/venice_image/image_vision/image_vision_base.py +17 -17
- intentkit/skills/venice_image/image_vision/image_vision_input.py +9 -9
- intentkit/skills/venice_image/utils.py +77 -78
- intentkit/skills/web_scraper/__init__.py +5 -18
- intentkit/skills/web_scraper/base.py +21 -7
- intentkit/skills/web_scraper/document_indexer.py +7 -6
- intentkit/skills/web_scraper/scrape_and_index.py +15 -15
- intentkit/skills/web_scraper/utils.py +62 -63
- intentkit/skills/web_scraper/website_indexer.py +17 -19
- intentkit/skills/weth/__init__.py +5 -11
- intentkit/skills/wow/__init__.py +5 -11
- intentkit/skills/x402/__init__.py +61 -0
- intentkit/skills/x402/ask_agent.py +98 -0
- intentkit/skills/x402/base.py +99 -0
- intentkit/skills/x402/http_request.py +117 -0
- intentkit/skills/x402/schema.json +45 -0
- intentkit/skills/x402/x402.webp +0 -0
- intentkit/skills/xmtp/__init__.py +4 -15
- intentkit/skills/xmtp/base.py +5 -5
- intentkit/skills/xmtp/price.py +6 -6
- intentkit/skills/xmtp/swap.py +6 -8
- intentkit/skills/xmtp/transfer.py +4 -6
- intentkit/utils/error.py +2 -2
- intentkit/utils/logging.py +2 -4
- intentkit/utils/s3.py +8 -9
- intentkit/utils/schema.py +100 -0
- intentkit/utils/slack_alert.py +7 -8
- {intentkit-0.8.6.dev2.dist-info → intentkit-0.8.17.dist-info}/METADATA +3 -4
- intentkit-0.8.17.dist-info/RECORD +466 -0
- intentkit/models/generator.py +0 -347
- intentkit-0.8.6.dev2.dist-info/RECORD +0 -457
- {intentkit-0.8.6.dev2.dist-info → intentkit-0.8.17.dist-info}/WHEEL +0 -0
- {intentkit-0.8.6.dev2.dist-info → intentkit-0.8.17.dist-info}/licenses/LICENSE +0 -0
|
@@ -1,121 +1,117 @@
|
|
|
1
|
-
import logging
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
from
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
from intentkit.
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
class
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
#
|
|
106
|
-
limit_num
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
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
|
|
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:
|
|
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:
|
|
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,12 +1,11 @@
|
|
|
1
1
|
import hashlib
|
|
2
2
|
import json
|
|
3
3
|
import logging
|
|
4
|
-
from typing import Any
|
|
4
|
+
from typing import Any
|
|
5
5
|
|
|
6
6
|
import httpx
|
|
7
|
-
from pydantic import BaseModel
|
|
7
|
+
from pydantic import BaseModel
|
|
8
8
|
|
|
9
|
-
from intentkit.abstracts.skill import SkillStoreABC
|
|
10
9
|
from intentkit.skills.venice_audio.base import VeniceAudioBaseTool
|
|
11
10
|
from intentkit.skills.venice_audio.input import AllowedAudioFormat, VeniceAudioInput
|
|
12
11
|
from intentkit.utils.s3 import store_file
|
|
@@ -33,19 +32,16 @@ class VeniceAudioTool(VeniceAudioBaseTool):
|
|
|
33
32
|
"Requires input text. Optional parameters include speed (0.25-4.0, default 1.0) "
|
|
34
33
|
"and audio format (mp3, opus, aac, flac, wav, pcm, default mp3)."
|
|
35
34
|
)
|
|
36
|
-
args_schema:
|
|
37
|
-
skill_store: SkillStoreABC = Field(
|
|
38
|
-
description="The skill store instance for accessing system/agent configurations and persisting data."
|
|
39
|
-
)
|
|
35
|
+
args_schema: type[BaseModel] = VeniceAudioInput
|
|
40
36
|
|
|
41
37
|
async def _arun(
|
|
42
38
|
self,
|
|
43
39
|
voice_input: str,
|
|
44
40
|
voice_model: str,
|
|
45
|
-
speed:
|
|
46
|
-
response_format:
|
|
41
|
+
speed: float | None = 1.0,
|
|
42
|
+
response_format: AllowedAudioFormat | None = "mp3",
|
|
47
43
|
**kwargs, # type: ignore
|
|
48
|
-
) ->
|
|
44
|
+
) -> dict[str, Any]:
|
|
49
45
|
"""
|
|
50
46
|
Generates audio using the configured voice model via Venice AI TTS /audio/speech endpoint.
|
|
51
47
|
Stores the resulting audio using the generic S3 helper.
|
|
@@ -96,7 +92,7 @@ class VeniceAudioTool(VeniceAudioBaseTool):
|
|
|
96
92
|
await self.apply_rate_limit(context)
|
|
97
93
|
|
|
98
94
|
# --- Prepare API Call ---
|
|
99
|
-
payload:
|
|
95
|
+
payload: dict[str, Any] = {
|
|
100
96
|
"model": tts_model_id,
|
|
101
97
|
"input": voice_input,
|
|
102
98
|
"voice": voice_model,
|