Skip to content

Commit d252fbf

Browse files
committed
feat(auth): support auto auth for run code
1 parent 18f7f07 commit d252fbf

File tree

1 file changed

+23
-5
lines changed

1 file changed

+23
-5
lines changed

veadk/tools/builtin_tools/run_code.py

Lines changed: 23 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -13,12 +13,14 @@
1313
# limitations under the License.
1414

1515
import json
16+
import os
1617

1718
from google.adk.tools import ToolContext
1819

1920
from veadk.config import getenv
2021
from veadk.utils.logger import get_logger
2122
from veadk.utils.volcengine_sign import ve_request
23+
from veadk.auth.veauth.utils import get_credential_from_vefaas_iam
2224

2325
logger = get_logger(__name__)
2426

@@ -51,8 +53,24 @@ def run_code(code: str, language: str, tool_context: ToolContext) -> str:
5153
f"Running code in language: {language}, session_id={session_id}, code={code}, tool_id={tool_id}, host={host}, service={service}, region={region}"
5254
)
5355

54-
access_key = getenv("VOLCENGINE_ACCESS_KEY")
55-
secret_key = getenv("VOLCENGINE_SECRET_KEY")
56+
ak = tool_context.state.get("VOLCENGINE_ACCESS_KEY")
57+
sk = tool_context.state.get("VOLCENGINE_SECRET_KEY")
58+
header = {}
59+
60+
if not (ak and sk):
61+
logger.debug("Get AK/SK from tool context failed.")
62+
ak = os.getenv("VOLCENGINE_ACCESS_KEY")
63+
sk = os.getenv("VOLCENGINE_SECRET_KEY")
64+
if not (ak and sk):
65+
logger.debug("Get AK/SK from environment variables failed. Try to use credential from Iam.")
66+
credential = get_credential_from_vefaas_iam()
67+
ak = credential.access_key_id
68+
sk = credential.secret_access_key
69+
header = {"X-Security-Token": credential.session_token}
70+
else:
71+
logger.debug("Successfully get AK/SK from environment variables.")
72+
else:
73+
logger.debug("Successfully get AK/SK from tool context.")
5674

5775
res = ve_request(
5876
request_body={
@@ -68,14 +86,14 @@ def run_code(code: str, language: str, tool_context: ToolContext) -> str:
6886
),
6987
},
7088
action="InvokeTool",
71-
ak=access_key,
72-
sk=secret_key,
89+
ak=ak,
90+
sk=sk,
7391
service=service,
7492
version="2025-10-30",
7593
region=region,
7694
host=host,
95+
header=header
7796
)
78-
7997
logger.debug(f"Invoke run code response: {res}")
8098

8199
try:

0 commit comments

Comments
 (0)