intentkit 0.8.11.dev1__py3-none-any.whl → 0.8.12__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


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

Files changed (183) hide show
  1. intentkit/__init__.py +1 -1
  2. intentkit/abstracts/graph.py +4 -0
  3. intentkit/abstracts/skill.py +2 -140
  4. intentkit/clients/twitter.py +35 -28
  5. intentkit/core/agent.py +2 -374
  6. intentkit/core/asset.py +63 -16
  7. intentkit/core/engine.py +16 -7
  8. intentkit/core/scheduler.py +8 -8
  9. intentkit/models/agent.py +109 -94
  10. intentkit/models/agent_schema.json +6 -9
  11. intentkit/models/llm.csv +15 -12
  12. intentkit/models/skill.py +38 -40
  13. intentkit/skills/acolyt/__init__.py +2 -9
  14. intentkit/skills/acolyt/base.py +2 -5
  15. intentkit/skills/aixbt/__init__.py +2 -13
  16. intentkit/skills/aixbt/base.py +0 -4
  17. intentkit/skills/aixbt/projects.py +1 -2
  18. intentkit/skills/allora/__init__.py +2 -9
  19. intentkit/skills/allora/base.py +2 -5
  20. intentkit/skills/base.py +168 -27
  21. intentkit/skills/basename/__init__.py +1 -3
  22. intentkit/skills/carv/__init__.py +116 -121
  23. intentkit/skills/carv/base.py +184 -185
  24. intentkit/skills/casino/__init__.py +4 -15
  25. intentkit/skills/casino/base.py +0 -4
  26. intentkit/skills/casino/deck_draw.py +4 -6
  27. intentkit/skills/casino/deck_shuffle.py +5 -4
  28. intentkit/skills/casino/dice_roll.py +1 -2
  29. intentkit/skills/cdp/__init__.py +0 -5
  30. intentkit/skills/cdp/base.py +0 -4
  31. intentkit/skills/cdp/schema.json +1 -17
  32. intentkit/skills/chainlist/__init__.py +2 -7
  33. intentkit/skills/chainlist/base.py +0 -4
  34. intentkit/skills/common/__init__.py +2 -9
  35. intentkit/skills/common/base.py +0 -4
  36. intentkit/skills/cookiefun/__init__.py +6 -9
  37. intentkit/skills/cookiefun/base.py +0 -4
  38. intentkit/skills/cryptocompare/__init__.py +7 -24
  39. intentkit/skills/cryptocompare/base.py +4 -18
  40. intentkit/skills/cryptocompare/fetch_news.py +1 -1
  41. intentkit/skills/cryptocompare/fetch_price.py +1 -1
  42. intentkit/skills/cryptocompare/fetch_top_exchanges.py +1 -1
  43. intentkit/skills/cryptocompare/fetch_top_market_cap.py +1 -1
  44. intentkit/skills/cryptocompare/fetch_top_volume.py +1 -1
  45. intentkit/skills/cryptocompare/fetch_trading_signals.py +1 -1
  46. intentkit/skills/cryptopanic/__init__.py +3 -6
  47. intentkit/skills/cryptopanic/base.py +53 -55
  48. intentkit/skills/cryptopanic/fetch_crypto_news.py +0 -2
  49. intentkit/skills/cryptopanic/fetch_crypto_sentiment.py +1 -3
  50. intentkit/skills/dapplooker/__init__.py +2 -9
  51. intentkit/skills/dapplooker/base.py +2 -5
  52. intentkit/skills/defillama/__init__.py +24 -74
  53. intentkit/skills/defillama/base.py +3 -13
  54. intentkit/skills/defillama/coins/fetch_batch_historical_prices.py +2 -2
  55. intentkit/skills/defillama/coins/fetch_block.py +2 -2
  56. intentkit/skills/defillama/coins/fetch_current_prices.py +2 -2
  57. intentkit/skills/defillama/coins/fetch_first_price.py +2 -2
  58. intentkit/skills/defillama/coins/fetch_historical_prices.py +2 -2
  59. intentkit/skills/defillama/coins/fetch_price_chart.py +2 -2
  60. intentkit/skills/defillama/coins/fetch_price_percentage.py +2 -2
  61. intentkit/skills/defillama/fees/fetch_fees_overview.py +2 -2
  62. intentkit/skills/defillama/stablecoins/fetch_stablecoin_chains.py +2 -2
  63. intentkit/skills/defillama/stablecoins/fetch_stablecoin_charts.py +2 -2
  64. intentkit/skills/defillama/stablecoins/fetch_stablecoin_prices.py +2 -2
  65. intentkit/skills/defillama/stablecoins/fetch_stablecoins.py +2 -2
  66. intentkit/skills/defillama/tvl/fetch_chain_historical_tvl.py +2 -2
  67. intentkit/skills/defillama/tvl/fetch_chains.py +2 -2
  68. intentkit/skills/defillama/tvl/fetch_historical_tvl.py +2 -2
  69. intentkit/skills/defillama/tvl/fetch_protocol.py +2 -2
  70. intentkit/skills/defillama/tvl/fetch_protocol_current_tvl.py +2 -2
  71. intentkit/skills/defillama/tvl/fetch_protocols.py +2 -2
  72. intentkit/skills/defillama/volumes/fetch_dex_overview.py +2 -2
  73. intentkit/skills/defillama/volumes/fetch_dex_summary.py +2 -2
  74. intentkit/skills/defillama/volumes/fetch_options_overview.py +2 -2
  75. intentkit/skills/defillama/yields/fetch_pool_chart.py +2 -2
  76. intentkit/skills/defillama/yields/fetch_pools.py +2 -2
  77. intentkit/skills/dexscreener/__init__.py +97 -102
  78. intentkit/skills/dexscreener/base.py +125 -130
  79. intentkit/skills/dexscreener/get_pair_info.py +2 -3
  80. intentkit/skills/dexscreener/get_token_pairs.py +2 -3
  81. intentkit/skills/dexscreener/get_tokens_info.py +2 -3
  82. intentkit/skills/dexscreener/search_token.py +2 -4
  83. intentkit/skills/dune_analytics/__init__.py +4 -6
  84. intentkit/skills/dune_analytics/base.py +50 -52
  85. intentkit/skills/dune_analytics/fetch_kol_buys.py +0 -2
  86. intentkit/skills/dune_analytics/fetch_nation_metrics.py +0 -2
  87. intentkit/skills/elfa/__init__.py +5 -18
  88. intentkit/skills/elfa/base.py +8 -10
  89. intentkit/skills/enso/__init__.py +9 -29
  90. intentkit/skills/enso/base.py +3 -6
  91. intentkit/skills/enso/networks.py +1 -6
  92. intentkit/skills/enso/route.py +4 -8
  93. intentkit/skills/enso/tokens.py +2 -12
  94. intentkit/skills/erc20/__init__.py +1 -5
  95. intentkit/skills/erc721/__init__.py +1 -3
  96. intentkit/skills/firecrawl/__init__.py +5 -18
  97. intentkit/skills/firecrawl/base.py +2 -5
  98. intentkit/skills/firecrawl/clear.py +3 -6
  99. intentkit/skills/firecrawl/crawl.py +10 -9
  100. intentkit/skills/firecrawl/query.py +3 -1
  101. intentkit/skills/firecrawl/scrape.py +10 -14
  102. intentkit/skills/firecrawl/utils.py +39 -31
  103. intentkit/skills/github/__init__.py +2 -7
  104. intentkit/skills/github/base.py +0 -4
  105. intentkit/skills/heurist/__init__.py +8 -27
  106. intentkit/skills/heurist/base.py +2 -5
  107. intentkit/skills/heurist/image_generation_animagine_xl.py +5 -5
  108. intentkit/skills/heurist/image_generation_arthemy_comics.py +5 -5
  109. intentkit/skills/heurist/image_generation_arthemy_real.py +5 -5
  110. intentkit/skills/heurist/image_generation_braindance.py +5 -5
  111. intentkit/skills/heurist/image_generation_cyber_realistic_xl.py +5 -5
  112. intentkit/skills/heurist/image_generation_flux_1_dev.py +5 -5
  113. intentkit/skills/heurist/image_generation_sdxl.py +5 -5
  114. intentkit/skills/http/__init__.py +4 -15
  115. intentkit/skills/http/base.py +0 -4
  116. intentkit/skills/lifi/__init__.py +1 -6
  117. intentkit/skills/lifi/base.py +0 -4
  118. intentkit/skills/lifi/token_execute.py +1 -4
  119. intentkit/skills/lifi/token_quote.py +1 -3
  120. intentkit/skills/moralis/__init__.py +3 -7
  121. intentkit/skills/moralis/base.py +2 -5
  122. intentkit/skills/morpho/__init__.py +1 -3
  123. intentkit/skills/nation/__init__.py +2 -7
  124. intentkit/skills/nation/base.py +4 -7
  125. intentkit/skills/openai/__init__.py +5 -18
  126. intentkit/skills/openai/base.py +8 -10
  127. intentkit/skills/openai/dalle_image_generation.py +2 -5
  128. intentkit/skills/openai/gpt_image_generation.py +2 -5
  129. intentkit/skills/openai/gpt_image_to_image.py +2 -5
  130. intentkit/skills/openai/image_to_text.py +2 -5
  131. intentkit/skills/portfolio/__init__.py +11 -35
  132. intentkit/skills/portfolio/base.py +2 -5
  133. intentkit/skills/pyth/__init__.py +1 -5
  134. intentkit/skills/slack/__init__.py +5 -17
  135. intentkit/skills/slack/base.py +0 -4
  136. intentkit/skills/supabase/__init__.py +7 -23
  137. intentkit/skills/supabase/base.py +0 -4
  138. intentkit/skills/superfluid/__init__.py +1 -3
  139. intentkit/skills/system/__init__.py +7 -24
  140. intentkit/skills/system/add_autonomous_task.py +2 -2
  141. intentkit/skills/system/delete_autonomous_task.py +2 -2
  142. intentkit/skills/system/edit_autonomous_task.py +2 -4
  143. intentkit/skills/system/list_autonomous_tasks.py +2 -2
  144. intentkit/skills/system/read_agent_api_key.py +6 -4
  145. intentkit/skills/system/regenerate_agent_api_key.py +6 -4
  146. intentkit/skills/tavily/__init__.py +3 -12
  147. intentkit/skills/tavily/base.py +2 -5
  148. intentkit/skills/tavily/tavily_extract.py +1 -2
  149. intentkit/skills/tavily/tavily_search.py +3 -3
  150. intentkit/skills/token/__init__.py +5 -10
  151. intentkit/skills/token/base.py +2 -6
  152. intentkit/skills/twitter/__init__.py +11 -35
  153. intentkit/skills/twitter/base.py +18 -29
  154. intentkit/skills/twitter/follow_user.py +1 -4
  155. intentkit/skills/twitter/get_mentions.py +2 -8
  156. intentkit/skills/twitter/get_timeline.py +3 -10
  157. intentkit/skills/twitter/get_user_by_username.py +1 -4
  158. intentkit/skills/twitter/get_user_tweets.py +3 -10
  159. intentkit/skills/twitter/like_tweet.py +1 -4
  160. intentkit/skills/twitter/post_tweet.py +3 -5
  161. intentkit/skills/twitter/reply_tweet.py +3 -5
  162. intentkit/skills/twitter/retweet.py +1 -4
  163. intentkit/skills/twitter/search_tweets.py +3 -10
  164. intentkit/skills/unrealspeech/__init__.py +2 -7
  165. intentkit/skills/unrealspeech/base.py +0 -4
  166. intentkit/skills/venice_audio/__init__.py +99 -106
  167. intentkit/skills/venice_audio/base.py +118 -121
  168. intentkit/skills/venice_audio/venice_audio.py +1 -5
  169. intentkit/skills/venice_image/__init__.py +147 -154
  170. intentkit/skills/venice_image/base.py +185 -192
  171. intentkit/skills/web_scraper/__init__.py +5 -18
  172. intentkit/skills/web_scraper/base.py +20 -4
  173. intentkit/skills/web_scraper/document_indexer.py +6 -4
  174. intentkit/skills/web_scraper/scrape_and_index.py +11 -10
  175. intentkit/skills/web_scraper/utils.py +38 -38
  176. intentkit/skills/web_scraper/website_indexer.py +7 -8
  177. intentkit/skills/weth/__init__.py +1 -5
  178. intentkit/skills/wow/__init__.py +1 -5
  179. intentkit/skills/xmtp/__init__.py +4 -15
  180. {intentkit-0.8.11.dev1.dist-info → intentkit-0.8.12.dist-info}/METADATA +1 -1
  181. {intentkit-0.8.11.dev1.dist-info → intentkit-0.8.12.dist-info}/RECORD +183 -183
  182. {intentkit-0.8.11.dev1.dist-info → intentkit-0.8.12.dist-info}/WHEEL +0 -0
  183. {intentkit-0.8.11.dev1.dist-info → intentkit-0.8.12.dist-info}/licenses/LICENSE +0 -0
@@ -1,154 +1,147 @@
1
- import logging
2
- from typing import NotRequired, Optional, TypedDict
3
-
4
- from intentkit.abstracts.skill import SkillStoreABC
5
- from intentkit.skills.base import (
6
- SkillConfig,
7
- SkillState,
8
- )
9
-
10
- # Import the base tool and all specific model skill classes
11
- from intentkit.skills.venice_image.base import VeniceImageBaseTool
12
- from intentkit.skills.venice_image.image_enhance.image_enhance import ImageEnhance
13
- from intentkit.skills.venice_image.image_generation.image_generation_fluently_xl import (
14
- ImageGenerationFluentlyXL,
15
- )
16
- from intentkit.skills.venice_image.image_generation.image_generation_flux_dev import (
17
- ImageGenerationFluxDev,
18
- )
19
- from intentkit.skills.venice_image.image_generation.image_generation_flux_dev_uncensored import (
20
- ImageGenerationFluxDevUncensored,
21
- )
22
- from intentkit.skills.venice_image.image_generation.image_generation_lustify_sdxl import (
23
- ImageGenerationLustifySDXL,
24
- )
25
- from intentkit.skills.venice_image.image_generation.image_generation_pony_realism import (
26
- ImageGenerationPonyRealism,
27
- )
28
- from intentkit.skills.venice_image.image_generation.image_generation_stable_diffusion_3_5 import (
29
- ImageGenerationStableDiffusion35,
30
- )
31
- from intentkit.skills.venice_image.image_generation.image_generation_venice_sd35 import (
32
- ImageGenerationVeniceSD35,
33
- )
34
- from intentkit.skills.venice_image.image_upscale.image_upscale import ImageUpscale
35
- from intentkit.skills.venice_image.image_vision.image_vision import ImageVision
36
-
37
- # Cache skills at the system level, because they are stateless and only depend on the store
38
- _cache: dict[str, VeniceImageBaseTool] = {}
39
-
40
- logger = logging.getLogger(__name__)
41
-
42
-
43
- # Define the expected structure for the 'states' dictionary in the config
44
- class SkillStates(TypedDict):
45
- image_upscale: SkillState
46
- image_enhance: SkillState
47
- image_vision: SkillState
48
- image_generation_flux_dev: SkillState
49
- image_generation_flux_dev_uncensored: SkillState
50
- image_generation_venice_sd35: SkillState
51
- image_generation_fluently_xl: SkillState
52
- image_generation_lustify_sdxl: SkillState
53
- image_generation_pony_realism: SkillState
54
- image_generation_stable_diffusion_3_5: SkillState
55
- # Add new skill names here if more models are added
56
-
57
-
58
- # Define the overall configuration structure for the venice_image category
59
- class Config(SkillConfig):
60
- """Configuration for Venice Image skills."""
61
-
62
- enabled: bool # Keep standard enabled flag
63
- states: SkillStates
64
- api_key_provider: str = "agent_owner"
65
- api_key: NotRequired[Optional[str]] # Explicitly Optional
66
- safe_mode: NotRequired[bool] # Defaults handled in base or usage
67
- hide_watermark: NotRequired[bool] # Defaults handled in base or usage
68
- negative_prompt: NotRequired[str] # Defaults handled in base or usage
69
- rate_limit_number: NotRequired[Optional[int]] # Explicitly Optional
70
- rate_limit_minutes: NotRequired[Optional[int]] # Explicitly Optional
71
-
72
-
73
- _SKILL_NAME_TO_CLASS_MAP: dict[str, type[VeniceImageBaseTool]] = {
74
- "image_upscale": ImageUpscale,
75
- "image_enhance": ImageEnhance,
76
- "image_vision": ImageVision,
77
- "image_generation_flux_dev": ImageGenerationFluxDev,
78
- "image_generation_flux_dev_uncensored": ImageGenerationFluxDevUncensored,
79
- "image_generation_venice_sd35": ImageGenerationVeniceSD35,
80
- "image_generation_fluently_xl": ImageGenerationFluentlyXL,
81
- "image_generation_lustify_sdxl": ImageGenerationLustifySDXL,
82
- "image_generation_pony_realism": ImageGenerationPonyRealism,
83
- "image_generation_stable_diffusion_3_5": ImageGenerationStableDiffusion35,
84
- }
85
-
86
-
87
- async def get_skills(
88
- config: "Config",
89
- is_private: bool,
90
- store: SkillStoreABC,
91
- **_, # Allow for extra arguments if the loader passes them
92
- ) -> list[VeniceImageBaseTool]:
93
- """Get all enabled Venice Image skills based on configuration and privacy level.
94
-
95
- Args:
96
- config: The configuration for Venice Image skills.
97
- is_private: Whether the context is private (e.g., agent owner).
98
- store: The skill store for persisting data and accessing system config.
99
-
100
- Returns:
101
- A list of instantiated and enabled Venice Image skill objects.
102
- """
103
- # Check if the entire category is disabled first
104
- if not config.get("enabled", False):
105
- return []
106
-
107
- available_skills: list[VeniceImageBaseTool] = []
108
-
109
- # Include skills based on their state
110
- for skill_name, state in config["states"].items():
111
- if state == "disabled":
112
- continue
113
- elif state == "public" or (state == "private" and is_private):
114
- available_skills.append(skill_name)
115
-
116
- # Get each skill using the cached getter
117
- result = []
118
- for name in available_skills:
119
- skill = get_venice_image_skill(name, store, config)
120
- if skill:
121
- result.append(skill)
122
- return result
123
-
124
-
125
- def get_venice_image_skill(
126
- name: str,
127
- store: SkillStoreABC,
128
- config: "Config",
129
- ) -> Optional[VeniceImageBaseTool]:
130
- """
131
- Factory function to get a cached Venice Image skill instance by name.
132
-
133
- Args:
134
- name: The name of the skill to get (must match keys in _SKILL_NAME_TO_CLASS_MAP).
135
- store: The skill store, passed to the skill constructor.
136
-
137
- Returns:
138
- The requested Venice Image skill instance, or None if the name is unknown.
139
- """
140
-
141
- # Return from cache immediately if already exists
142
- if name in _cache:
143
- return _cache[name]
144
-
145
- skill_class = _SKILL_NAME_TO_CLASS_MAP.get(name)
146
- if not skill_class:
147
- logger.warning(f"Unknown Venice skill: {name}")
148
- return None
149
-
150
- # Cache and return the newly created instance
151
- _cache[name] = skill_class(
152
- skill_store=store,
153
- )
154
- return _cache[name]
1
+ import logging
2
+ from typing import NotRequired, Optional, TypedDict
3
+
4
+ from intentkit.skills.base import (
5
+ SkillConfig,
6
+ SkillState,
7
+ )
8
+
9
+ # Import the base tool and all specific model skill classes
10
+ from intentkit.skills.venice_image.base import VeniceImageBaseTool
11
+ from intentkit.skills.venice_image.image_enhance.image_enhance import ImageEnhance
12
+ from intentkit.skills.venice_image.image_generation.image_generation_fluently_xl import (
13
+ ImageGenerationFluentlyXL,
14
+ )
15
+ from intentkit.skills.venice_image.image_generation.image_generation_flux_dev import (
16
+ ImageGenerationFluxDev,
17
+ )
18
+ from intentkit.skills.venice_image.image_generation.image_generation_flux_dev_uncensored import (
19
+ ImageGenerationFluxDevUncensored,
20
+ )
21
+ from intentkit.skills.venice_image.image_generation.image_generation_lustify_sdxl import (
22
+ ImageGenerationLustifySDXL,
23
+ )
24
+ from intentkit.skills.venice_image.image_generation.image_generation_pony_realism import (
25
+ ImageGenerationPonyRealism,
26
+ )
27
+ from intentkit.skills.venice_image.image_generation.image_generation_stable_diffusion_3_5 import (
28
+ ImageGenerationStableDiffusion35,
29
+ )
30
+ from intentkit.skills.venice_image.image_generation.image_generation_venice_sd35 import (
31
+ ImageGenerationVeniceSD35,
32
+ )
33
+ from intentkit.skills.venice_image.image_upscale.image_upscale import ImageUpscale
34
+ from intentkit.skills.venice_image.image_vision.image_vision import ImageVision
35
+
36
+ # Cache skills at the system level, because they are stateless and only depend on the store
37
+ _cache: dict[str, VeniceImageBaseTool] = {}
38
+
39
+ logger = logging.getLogger(__name__)
40
+
41
+
42
+ # Define the expected structure for the 'states' dictionary in the config
43
+ class SkillStates(TypedDict):
44
+ image_upscale: SkillState
45
+ image_enhance: SkillState
46
+ image_vision: SkillState
47
+ image_generation_flux_dev: SkillState
48
+ image_generation_flux_dev_uncensored: SkillState
49
+ image_generation_venice_sd35: SkillState
50
+ image_generation_fluently_xl: SkillState
51
+ image_generation_lustify_sdxl: SkillState
52
+ image_generation_pony_realism: SkillState
53
+ image_generation_stable_diffusion_3_5: SkillState
54
+ # Add new skill names here if more models are added
55
+
56
+
57
+ # Define the overall configuration structure for the venice_image category
58
+ class Config(SkillConfig):
59
+ """Configuration for Venice Image skills."""
60
+
61
+ enabled: bool # Keep standard enabled flag
62
+ states: SkillStates
63
+ api_key_provider: str = "agent_owner"
64
+ api_key: NotRequired[Optional[str]] # Explicitly Optional
65
+ safe_mode: NotRequired[bool] # Defaults handled in base or usage
66
+ hide_watermark: NotRequired[bool] # Defaults handled in base or usage
67
+ negative_prompt: NotRequired[str] # Defaults handled in base or usage
68
+ rate_limit_number: NotRequired[Optional[int]] # Explicitly Optional
69
+ rate_limit_minutes: NotRequired[Optional[int]] # Explicitly Optional
70
+
71
+
72
+ _SKILL_NAME_TO_CLASS_MAP: dict[str, type[VeniceImageBaseTool]] = {
73
+ "image_upscale": ImageUpscale,
74
+ "image_enhance": ImageEnhance,
75
+ "image_vision": ImageVision,
76
+ "image_generation_flux_dev": ImageGenerationFluxDev,
77
+ "image_generation_flux_dev_uncensored": ImageGenerationFluxDevUncensored,
78
+ "image_generation_venice_sd35": ImageGenerationVeniceSD35,
79
+ "image_generation_fluently_xl": ImageGenerationFluentlyXL,
80
+ "image_generation_lustify_sdxl": ImageGenerationLustifySDXL,
81
+ "image_generation_pony_realism": ImageGenerationPonyRealism,
82
+ "image_generation_stable_diffusion_3_5": ImageGenerationStableDiffusion35,
83
+ }
84
+
85
+
86
+ async def get_skills(
87
+ config: "Config",
88
+ is_private: bool,
89
+ **_, # Allow for extra arguments if the loader passes them
90
+ ) -> list[VeniceImageBaseTool]:
91
+ """Get all enabled Venice Image skills based on configuration and privacy level.
92
+
93
+ Args:
94
+ config: The configuration for Venice Image skills.
95
+ is_private: Whether the context is private (e.g., agent owner).
96
+
97
+ Returns:
98
+ A list of instantiated and enabled Venice Image skill objects.
99
+ """
100
+ # Check if the entire category is disabled first
101
+ if not config.get("enabled", False):
102
+ return []
103
+
104
+ available_skills: list[VeniceImageBaseTool] = []
105
+
106
+ # Include skills based on their state
107
+ for skill_name, state in config["states"].items():
108
+ if state == "disabled":
109
+ continue
110
+ elif state == "public" or (state == "private" and is_private):
111
+ available_skills.append(skill_name)
112
+
113
+ # Get each skill using the cached getter
114
+ result = []
115
+ for name in available_skills:
116
+ skill = get_venice_image_skill(name, config)
117
+ if skill:
118
+ result.append(skill)
119
+ return result
120
+
121
+
122
+ def get_venice_image_skill(
123
+ name: str,
124
+ config: "Config",
125
+ ) -> Optional[VeniceImageBaseTool]:
126
+ """
127
+ Factory function to get a cached Venice Image skill instance by name.
128
+
129
+ Args:
130
+ name: The name of the skill to get (must match keys in _SKILL_NAME_TO_CLASS_MAP).
131
+
132
+ Returns:
133
+ The requested Venice Image skill instance, or None if the name is unknown.
134
+ """
135
+
136
+ # Return from cache immediately if already exists
137
+ if name in _cache:
138
+ return _cache[name]
139
+
140
+ skill_class = _SKILL_NAME_TO_CLASS_MAP.get(name)
141
+ if not skill_class:
142
+ logger.warning(f"Unknown Venice skill: {name}")
143
+ return None
144
+
145
+ # Cache and return the newly created instance
146
+ _cache[name] = skill_class()
147
+ return _cache[name]