veadk-python 0.2.13__py3-none-any.whl → 0.2.15__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 veadk-python might be problematic. Click here for more details.

veadk/cli/cli.py CHANGED
@@ -18,6 +18,7 @@ import click
18
18
  from veadk.cli.cli_deploy import deploy
19
19
  from veadk.cli.cli_eval import eval
20
20
  from veadk.cli.cli_init import init
21
+ from veadk.cli.cli_create import create
21
22
  from veadk.cli.cli_kb import kb
22
23
  from veadk.cli.cli_pipeline import pipeline
23
24
  from veadk.cli.cli_prompt import prompt
@@ -37,6 +38,7 @@ def veadk():
37
38
 
38
39
  veadk.add_command(deploy)
39
40
  veadk.add_command(init)
41
+ veadk.add_command(create)
40
42
  veadk.add_command(prompt)
41
43
  veadk.add_command(web)
42
44
  veadk.add_command(pipeline)
@@ -0,0 +1,122 @@
1
+ # Copyright (c) 2025 Beijing Volcano Engine Technology Co., Ltd. and/or its affiliates.
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+
15
+ import click
16
+ import shutil
17
+ from pathlib import Path
18
+
19
+ _CONFIG_YAML_TEMPLATE = """\
20
+ model:
21
+ agent:
22
+ name: doubao-seed-1-6-251015
23
+ api_key: {ark_api_key}
24
+ video:
25
+ name: doubao-seedance-1-0-pro-250528
26
+ # if you want to use different api_key, just uncomment following line and complete api_key
27
+ # api_key:
28
+ image:
29
+ name: doubao-seedream-4-0-250828
30
+ # if you want to use different api_key, just uncomment following line and complete api_key
31
+ # api_key:
32
+
33
+ logging:
34
+ # ERROR
35
+ # WARNING
36
+ # INFO
37
+ # DEBUG
38
+ level: DEBUG
39
+ """
40
+
41
+ _INIT_PY_TEMPLATE = """\
42
+ from . import agent
43
+ """
44
+
45
+ _AGENT_PY_TEMPLATE = """\
46
+ from veadk import Agent
47
+
48
+ root_agent = Agent(
49
+ name="root_agent",
50
+ description="A helpful assistant for user questions.",
51
+ instruction="Answer user questions to the best of your knowledge",
52
+ )
53
+ """
54
+
55
+ _SUCCESS_MSG = """\
56
+ Agent '{agent_name}' created successfully at '{agent_folder}':
57
+ - config.yaml
58
+ - {agent_name}/__init__.py
59
+ - {agent_name}/agent.py
60
+
61
+ You can run the agent by executing: cd {agent_name} && veadk web
62
+ """
63
+
64
+
65
+ def _prompt_for_ark_api_key() -> str:
66
+ click.secho(
67
+ "An API key is required to run the agent. See https://www.volcengine.com/docs/82379/1541594 for details.",
68
+ fg="green",
69
+ )
70
+ click.echo("You have two options:")
71
+ click.echo(" 1. Enter the API key now.")
72
+ click.echo(" 2. Configure it later in the generated config.yaml file.")
73
+ choice = click.prompt("Please select an option", type=click.Choice(["1", "2"]))
74
+ if choice == "1":
75
+ return click.prompt("Please enter your ARK API key")
76
+ else:
77
+ click.secho(
78
+ "You can set the `api_key` in the config.yaml file later.", fg="yellow"
79
+ )
80
+ return ""
81
+
82
+
83
+ def _generate_files(agent_name: str, ark_api_key: str, target_dir_path: Path) -> None:
84
+ agent_dir_path = target_dir_path / agent_name
85
+ agent_dir_path.mkdir(parents=True, exist_ok=True)
86
+ config_yaml_path = target_dir_path / "config.yaml"
87
+ init_file_path = agent_dir_path / "__init__.py"
88
+ agent_file_path = agent_dir_path / "agent.py"
89
+
90
+ config_yaml_content = _CONFIG_YAML_TEMPLATE.format(ark_api_key=ark_api_key)
91
+ config_yaml_path.write_text(config_yaml_content)
92
+ init_file_path.write_text(_INIT_PY_TEMPLATE)
93
+ agent_file_path.write_text(_AGENT_PY_TEMPLATE)
94
+
95
+ click.secho(
96
+ _SUCCESS_MSG.format(agent_name=agent_name, agent_folder=target_dir_path),
97
+ fg="green",
98
+ )
99
+
100
+
101
+ @click.command()
102
+ @click.option("--agent-name", help="The name of the agent.")
103
+ @click.option("--ark-api-key", help="The ARK API key.")
104
+ def create(agent_name: str, ark_api_key: str) -> None:
105
+ """Creates a new agent in the current folder with prepopulated agent template."""
106
+ if not agent_name:
107
+ agent_name = click.prompt("Enter the agent name")
108
+ if not ark_api_key:
109
+ ark_api_key = _prompt_for_ark_api_key()
110
+
111
+ cwd = Path.cwd()
112
+ target_dir_path = cwd / agent_name
113
+
114
+ if target_dir_path.exists() and any(target_dir_path.iterdir()):
115
+ if not click.confirm(
116
+ f"Directory '{target_dir_path}' already exists and is not empty. Do you want to overwrite it?"
117
+ ):
118
+ click.secho("Operation cancelled.", fg="red")
119
+ return
120
+ shutil.rmtree(target_dir_path)
121
+
122
+ _generate_files(agent_name, ark_api_key, target_dir_path)
veadk/cli/cli_web.py CHANGED
@@ -12,99 +12,13 @@
12
12
  # See the License for the specific language governing permissions and
13
13
  # limitations under the License.
14
14
 
15
- from typing import Optional
15
+ from functools import wraps
16
16
 
17
17
  import click
18
18
 
19
- from veadk.memory.long_term_memory import LongTermMemory
20
- from veadk.memory.short_term_memory import ShortTermMemory
19
+ from veadk.utils.logger import get_logger
21
20
 
22
-
23
- def _get_stm_from_module(module) -> ShortTermMemory:
24
- return module.agent_run_config.short_term_memory
25
-
26
-
27
- def _get_stm_from_env() -> ShortTermMemory:
28
- import os
29
-
30
- from veadk.utils.logger import get_logger
31
-
32
- logger = get_logger(__name__)
33
-
34
- short_term_memory_backend = os.getenv("SHORT_TERM_MEMORY_BACKEND")
35
- if not short_term_memory_backend: # prevent None or empty string
36
- short_term_memory_backend = "local"
37
- logger.info(f"Short term memory: backend={short_term_memory_backend}")
38
-
39
- return ShortTermMemory(backend=short_term_memory_backend) # type: ignore
40
-
41
-
42
- def _get_ltm_from_module(module) -> LongTermMemory | None:
43
- agent = module.agent_run_config.agent
44
-
45
- if not hasattr(agent, "long_term_memory"):
46
- return None
47
- else:
48
- return agent.long_term_memory
49
-
50
-
51
- def _get_ltm_from_env() -> LongTermMemory | None:
52
- import os
53
-
54
- from veadk.utils.logger import get_logger
55
-
56
- logger = get_logger(__name__)
57
-
58
- long_term_memory_backend = os.getenv("LONG_TERM_MEMORY_BACKEND")
59
- app_name = os.getenv("VEADK_WEB_APP_NAME", "")
60
- user_id = os.getenv("VEADK_WEB_USER_ID", "")
61
-
62
- if long_term_memory_backend:
63
- logger.info(f"Long term memory: backend={long_term_memory_backend}")
64
- return LongTermMemory(
65
- backend=long_term_memory_backend, app_name=app_name, user_id=user_id
66
- ) # type: ignore
67
- else:
68
- logger.warning("No long term memory backend settings detected.")
69
- return None
70
-
71
-
72
- def _get_memory(
73
- module_path: str,
74
- ) -> tuple[ShortTermMemory, LongTermMemory | None]:
75
- from veadk.utils.logger import get_logger
76
- from veadk.utils.misc import load_module_from_file
77
-
78
- logger = get_logger(__name__)
79
-
80
- # 1. load user module
81
- try:
82
- module_file_path = module_path
83
- module = load_module_from_file(
84
- module_name="agent_and_mem", file_path=f"{module_file_path}/agent.py"
85
- )
86
- except Exception as e:
87
- logger.error(
88
- f"Failed to get memory config from `agent.py`: {e}. Fallback to get memory from environment variables."
89
- )
90
- return _get_stm_from_env(), _get_ltm_from_env()
91
-
92
- if not hasattr(module, "agent_run_config"):
93
- logger.error(
94
- "You must export `agent_run_config` as a global variable in `agent.py`. Fallback to get memory from environment variables."
95
- )
96
- return _get_stm_from_env(), _get_ltm_from_env()
97
-
98
- # 2. try to get short term memory
99
- # short term memory must exist in user code, as we use `default_factory` to init it
100
- short_term_memory = _get_stm_from_module(module)
101
-
102
- # 3. try to get long term memory
103
- long_term_memory = _get_ltm_from_module(module)
104
- if not long_term_memory:
105
- long_term_memory = _get_ltm_from_env()
106
-
107
- return short_term_memory, long_term_memory
21
+ logger = get_logger(__name__)
108
22
 
109
23
 
110
24
  def patch_adkwebserver_disable_openapi():
@@ -133,71 +47,66 @@ def patch_adkwebserver_disable_openapi():
133
47
  google.adk.cli.adk_web_server.AdkWebServer.get_fast_api_app = wrapped_get_fast_api
134
48
 
135
49
 
136
- @click.command()
137
- @click.option("--host", default="127.0.0.1", help="Host to run the web server on")
138
- @click.option(
139
- "--app_name", default="", help="The `app_name` for initializing long term memory"
140
- )
141
- @click.option(
142
- "--user_id", default="", help="The `user_id` for initializing long term memory"
50
+ @click.command(
51
+ context_settings=dict(ignore_unknown_options=True, allow_extra_args=True)
143
52
  )
144
- def web(host: str, app_name: str, user_id: str) -> None:
53
+ @click.pass_context
54
+ def web(ctx, *args, **kwargs) -> None:
145
55
  """Launch web with long term and short term memory."""
146
- import os
147
- from typing import Any
148
-
149
- from google.adk.cli.utils.shared_value import SharedValue
150
-
151
- from veadk.utils.logger import get_logger
152
-
153
- logger = get_logger(__name__)
154
-
155
- def init_for_veadk(
156
- self,
157
- *,
158
- agent_loader: Any,
159
- session_service: Any,
160
- memory_service: Any,
161
- artifact_service: Any,
162
- credential_service: Any,
163
- eval_sets_manager: Any,
164
- eval_set_results_manager: Any,
165
- agents_dir: str,
166
- extra_plugins: Optional[list[str]] = None,
167
- **kwargs: Any,
168
- ):
169
- self.agent_loader = agent_loader
170
- self.artifact_service = artifact_service
171
- self.credential_service = credential_service
172
- self.eval_sets_manager = eval_sets_manager
173
- self.eval_set_results_manager = eval_set_results_manager
174
- self.agents_dir = agents_dir
175
- self.runners_to_clean = set()
176
- self.current_app_name_ref = SharedValue(value="")
177
- self.runner_dict = {}
178
- self.extra_plugins = extra_plugins or []
179
-
180
- for key, value in kwargs.items():
181
- setattr(self, key, value)
182
-
183
- # parse VeADK memories
184
- short_term_memory, long_term_memory = _get_memory(module_path=agents_dir)
185
- self.session_service = short_term_memory.session_service
186
- self.memory_service = long_term_memory
187
-
188
- os.environ["VEADK_WEB_APP_NAME"] = app_name
189
- os.environ["VEADK_WEB_USER_ID"] = user_id
190
-
191
- import google.adk.cli.adk_web_server
56
+ from google.adk.cli import adk_web_server
57
+ from google.adk.runners import Runner as ADKRunner
58
+
59
+ from veadk import Agent
60
+ from veadk.agents.loop_agent import LoopAgent
61
+ from veadk.agents.parallel_agent import ParallelAgent
62
+ from veadk.agents.sequential_agent import SequentialAgent
63
+
64
+ def before_get_runner_async(func):
65
+ logger.info("Hook before `get_runner_async`")
66
+
67
+ @wraps(func)
68
+ async def wrapper(*args, **kwargs) -> ADKRunner:
69
+ self: adk_web_server.AdkWebServer = args[0]
70
+ app_name: str = args[1]
71
+ """Returns the cached runner for the given app."""
72
+ agent_or_app = self.agent_loader.load_agent(app_name)
73
+
74
+ if isinstance(agent_or_app, (SequentialAgent, LoopAgent, ParallelAgent)):
75
+ logger.warning(
76
+ "Detect VeADK workflow agent, the short-term memory and long-term memory of each sub agent are useless."
77
+ )
78
+
79
+ if isinstance(agent_or_app, Agent):
80
+ logger.info("Detect VeADK Agent.")
81
+
82
+ if agent_or_app.short_term_memory:
83
+ self.session_service = (
84
+ agent_or_app.short_term_memory.session_service
85
+ )
86
+
87
+ if agent_or_app.long_term_memory:
88
+ self.memory_service = agent_or_app.long_term_memory
89
+ logger.info(
90
+ f"Long term memory backend is {self.memory_service.backend}"
91
+ )
92
+
93
+ logger.info(
94
+ f"Current session_service={self.session_service.__class__.__name__}, memory_service={self.memory_service.__class__.__name__}"
95
+ )
96
+
97
+ runner = await func(*args, **kwargs)
98
+ return runner
99
+
100
+ return wrapper
101
+
102
+ adk_web_server.AdkWebServer.get_runner_async = before_get_runner_async(
103
+ adk_web_server.AdkWebServer.get_runner_async
104
+ )
192
105
 
193
- google.adk.cli.adk_web_server.AdkWebServer.__init__ = init_for_veadk
194
106
  patch_adkwebserver_disable_openapi()
195
107
 
196
- import google.adk.cli.cli_tools_click as cli_tools_click
197
-
198
- agents_dir = os.getcwd()
199
- logger.info(f"Load agents from {agents_dir}")
108
+ from google.adk.cli.cli_tools_click import cli_web
200
109
 
201
- cli_tools_click.cli_web.main(
202
- args=[agents_dir, "--host", host, "--log_level", "ERROR"]
203
- )
110
+ extra_args = ctx.args
111
+ logger.debug(f"User args: {ctx.args}")
112
+ cli_web.main(args=extra_args, standalone_mode=False)
veadk/consts.py CHANGED
@@ -62,9 +62,6 @@ DEFAULT_TOS_BUCKET_NAME = "ark-tutorial"
62
62
 
63
63
  DEFAULT_COZELOOP_SPACE_NAME = "VeADK Space"
64
64
 
65
- DEFAULT_TEXT_TO_IMAGE_MODEL_NAME = "doubao-seedream-3-0-t2i-250415"
66
- DEFAULT_TEXT_TO_IMAGE_MODEL_API_BASE = "https://ark.cn-beijing.volces.com/api/v3/"
67
-
68
65
  DEFAULT_IMAGE_EDIT_MODEL_NAME = "doubao-seededit-3-0-i2i-250628"
69
66
  DEFAULT_IMAGE_EDIT_MODEL_API_BASE = "https://ark.cn-beijing.volces.com/api/v3/"
70
67