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 +2 -0
- veadk/cli/cli_create.py +122 -0
- veadk/cli/cli_web.py +60 -151
- veadk/consts.py +0 -3
- veadk/tools/builtin_tools/generate_image.py +4 -411
- veadk/tools/builtin_tools/image_generate.py +319 -169
- veadk/version.py +1 -1
- {veadk_python-0.2.13.dist-info → veadk_python-0.2.15.dist-info}/METADATA +1 -1
- {veadk_python-0.2.13.dist-info → veadk_python-0.2.15.dist-info}/RECORD +13 -12
- {veadk_python-0.2.13.dist-info → veadk_python-0.2.15.dist-info}/WHEEL +0 -0
- {veadk_python-0.2.13.dist-info → veadk_python-0.2.15.dist-info}/entry_points.txt +0 -0
- {veadk_python-0.2.13.dist-info → veadk_python-0.2.15.dist-info}/licenses/LICENSE +0 -0
- {veadk_python-0.2.13.dist-info → veadk_python-0.2.15.dist-info}/top_level.txt +0 -0
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)
|
veadk/cli/cli_create.py
ADDED
|
@@ -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
|
|
15
|
+
from functools import wraps
|
|
16
16
|
|
|
17
17
|
import click
|
|
18
18
|
|
|
19
|
-
from veadk.
|
|
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
|
-
|
|
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
|
-
|
|
53
|
+
@click.pass_context
|
|
54
|
+
def web(ctx, *args, **kwargs) -> None:
|
|
145
55
|
"""Launch web with long term and short term memory."""
|
|
146
|
-
import
|
|
147
|
-
from
|
|
148
|
-
|
|
149
|
-
from
|
|
150
|
-
|
|
151
|
-
from veadk.
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
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
|
-
|
|
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
|
-
|
|
202
|
-
|
|
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
|
|