jvserve 2.0.6__tar.gz → 2.0.8__tar.gz
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 jvserve might be problematic. Click here for more details.
- {jvserve-2.0.6 → jvserve-2.0.8}/PKG-INFO +1 -1
- {jvserve-2.0.6 → jvserve-2.0.8}/jvserve/__init__.py +1 -1
- {jvserve-2.0.6 → jvserve-2.0.8}/jvserve/cli.py +3 -0
- {jvserve-2.0.6 → jvserve-2.0.8}/jvserve/lib/agent_interface.py +24 -13
- {jvserve-2.0.6 → jvserve-2.0.8}/jvserve.egg-info/PKG-INFO +1 -1
- {jvserve-2.0.6 → jvserve-2.0.8}/LICENSE +0 -0
- {jvserve-2.0.6 → jvserve-2.0.8}/README.md +0 -0
- {jvserve-2.0.6 → jvserve-2.0.8}/jvserve/lib/__init__.py +0 -0
- {jvserve-2.0.6 → jvserve-2.0.8}/jvserve/lib/agent_pulse.py +0 -0
- {jvserve-2.0.6 → jvserve-2.0.8}/jvserve/lib/file_interface.py +0 -0
- {jvserve-2.0.6 → jvserve-2.0.8}/jvserve/lib/jvlogger.py +0 -0
- {jvserve-2.0.6 → jvserve-2.0.8}/jvserve.egg-info/SOURCES.txt +0 -0
- {jvserve-2.0.6 → jvserve-2.0.8}/jvserve.egg-info/dependency_links.txt +0 -0
- {jvserve-2.0.6 → jvserve-2.0.8}/jvserve.egg-info/entry_points.txt +0 -0
- {jvserve-2.0.6 → jvserve-2.0.8}/jvserve.egg-info/requires.txt +0 -0
- {jvserve-2.0.6 → jvserve-2.0.8}/jvserve.egg-info/top_level.txt +0 -0
- {jvserve-2.0.6 → jvserve-2.0.8}/setup.cfg +0 -0
- {jvserve-2.0.6 → jvserve-2.0.8}/setup.py +0 -0
- {jvserve-2.0.6 → jvserve-2.0.8}/tests/test_file_interface.py +0 -0
- {jvserve-2.0.6 → jvserve-2.0.8}/tests/test_jvlogger.py +0 -0
- {jvserve-2.0.6 → jvserve-2.0.8}/tests/test_jvserve.py +0 -0
|
@@ -6,6 +6,7 @@ import time
|
|
|
6
6
|
from contextlib import asynccontextmanager
|
|
7
7
|
from typing import AsyncIterator, Optional
|
|
8
8
|
|
|
9
|
+
from dotenv import load_dotenv
|
|
9
10
|
from jac_cloud.jaseci.security import authenticator
|
|
10
11
|
from jaclang.cli.cmdreg import cmd_registry
|
|
11
12
|
from jaclang.plugin.default import hookimpl
|
|
@@ -17,6 +18,8 @@ from jvserve.lib.agent_interface import AgentInterface
|
|
|
17
18
|
from jvserve.lib.agent_pulse import AgentPulse
|
|
18
19
|
from jvserve.lib.jvlogger import JVLogger
|
|
19
20
|
|
|
21
|
+
load_dotenv(".env")
|
|
22
|
+
|
|
20
23
|
|
|
21
24
|
class JacCmd:
|
|
22
25
|
"""Jac CLI."""
|
|
@@ -11,7 +11,7 @@ from urllib.parse import quote, unquote
|
|
|
11
11
|
|
|
12
12
|
import aiohttp
|
|
13
13
|
import requests
|
|
14
|
-
from fastapi import Form, Request, UploadFile
|
|
14
|
+
from fastapi import File, Form, Request, UploadFile
|
|
15
15
|
from fastapi.responses import JSONResponse
|
|
16
16
|
from jac_cloud.core.architype import AnchorState, Permission, Root
|
|
17
17
|
from jac_cloud.core.context import (
|
|
@@ -158,12 +158,11 @@ class AgentInterface:
|
|
|
158
158
|
|
|
159
159
|
@staticmethod
|
|
160
160
|
async def action_walker_exec(
|
|
161
|
-
request: Request,
|
|
162
161
|
agent_id: str = Form(...), # noqa: B008
|
|
163
162
|
module_root: str = Form(...), # noqa: B008
|
|
164
163
|
walker: str = Form(...), # noqa: B008
|
|
165
164
|
args: Optional[str] = Form(None), # noqa: B008
|
|
166
|
-
attachments: List[UploadFile] =
|
|
165
|
+
attachments: List[UploadFile] = File(default_factory=list), # noqa: B008
|
|
167
166
|
) -> JSONResponse:
|
|
168
167
|
"""Execute a named walker exposed by an action within context; capable of handling JSON or file data depending on request"""
|
|
169
168
|
|
|
@@ -233,10 +232,13 @@ class AgentInterface:
|
|
|
233
232
|
"""Payload for interacting with the agent."""
|
|
234
233
|
|
|
235
234
|
agent_id: str
|
|
236
|
-
utterance: str
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
235
|
+
utterance: Optional[str] = None
|
|
236
|
+
channel: Optional[str] = None
|
|
237
|
+
session_id: Optional[str] = None
|
|
238
|
+
tts: Optional[bool] = None
|
|
239
|
+
verbose: Optional[bool] = None
|
|
240
|
+
data: Optional[list[dict]] = None
|
|
241
|
+
streaming: Optional[bool] = None
|
|
240
242
|
|
|
241
243
|
@staticmethod
|
|
242
244
|
def interact(payload: InteractPayload) -> dict:
|
|
@@ -260,10 +262,13 @@ class AgentInterface:
|
|
|
260
262
|
walker_name="interact",
|
|
261
263
|
attributes={
|
|
262
264
|
"agent_id": payload.agent_id,
|
|
263
|
-
"utterance": payload.utterance,
|
|
264
|
-
"
|
|
265
|
-
"
|
|
266
|
-
"
|
|
265
|
+
"utterance": payload.utterance or "",
|
|
266
|
+
"channel": payload.channel or "",
|
|
267
|
+
"session_id": session_id or "",
|
|
268
|
+
"tts": payload.tts or False,
|
|
269
|
+
"verbose": payload.verbose or False,
|
|
270
|
+
"data": payload.data or [],
|
|
271
|
+
"streaming": payload.streaming or False,
|
|
267
272
|
"reporting": False,
|
|
268
273
|
},
|
|
269
274
|
module_name="jivas.agent.action.interact",
|
|
@@ -384,8 +389,14 @@ class AgentInterface:
|
|
|
384
389
|
headers = {}
|
|
385
390
|
json = {
|
|
386
391
|
"agent_id": payload.agent_id,
|
|
387
|
-
"utterance": payload.utterance,
|
|
388
|
-
"
|
|
392
|
+
"utterance": payload.utterance or "",
|
|
393
|
+
"channel": payload.channel or "",
|
|
394
|
+
"session_id": session_id or "",
|
|
395
|
+
"tts": payload.tts or False,
|
|
396
|
+
"verbose": payload.verbose or False,
|
|
397
|
+
"data": payload.data or [],
|
|
398
|
+
"streaming": payload.streaming or False,
|
|
399
|
+
"reporting": False,
|
|
389
400
|
}
|
|
390
401
|
headers["Authorization"] = "Bearer " + AgentInterface.TOKEN
|
|
391
402
|
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|