From a860c797bd6b9b1498355094733a34b4f38aec2e Mon Sep 17 00:00:00 2001 From: Kye Date: Mon, 10 Jul 2023 09:48:16 -0400 Subject: [PATCH] api container Former-commit-id: 2ab64156732f78d7a2a648e83a096629afa46abb --- api/container.py | 24 ++++++++++++------------ swarms/utils/static.py | 28 ++++++++++++++++++++++++++++ 2 files changed, 40 insertions(+), 12 deletions(-) create mode 100644 swarms/utils/static.py diff --git a/api/container.py b/api/container.py index 7c61956a..6d32c6d4 100644 --- a/api/container.py +++ b/api/container.py @@ -5,16 +5,17 @@ from typing import Dict, List from fastapi.templating import Jinja2Templates -from swarms import Swarms -from swarms.utils.utils import BaseHandler, FileHandler, FileType, StaticUploader, CsvToDataframe +from swarms.agents.utils.manager import AgentManager +from swarms.utils.utils import BaseHandler, FileHandler, FileType +from swarms.tools.main import CsvToDataframe, ExitConversation, RequestsGet, CodeEditor, Terminal -from swarms.tools.main import BaseToolSet, ExitConversation, RequestsGet, CodeEditor, Terminal +from swarms.tools.main import BaseToolSet +from swarms.utils.utils import StaticUploader BASE_DIR = Path(os.path.dirname(os.path.dirname(os.path.abspath(__file__)))) -os.chdir(BASE_DIR / os.getenv("PLAYGROUND_DIR")) +os.chdir(BASE_DIR / os.environ["PLAYGROUND_DIR"]) -api_key = os.getenv("OPENAI_API_KEY") toolsets: List[BaseToolSet] = [ Terminal(), @@ -24,9 +25,10 @@ toolsets: List[BaseToolSet] = [ ] handlers: Dict[FileType, BaseHandler] = {FileType.DATAFRAME: CsvToDataframe()} -if os.getenv("USE_GPU") == "True": +if os.environ["USE_GPU"]: import torch + # from core.handlers.image import ImageCaptioning from swarms.tools.main import ImageCaptioning from swarms.tools.main import ( ImageEditing, @@ -46,16 +48,14 @@ if os.getenv("USE_GPU") == "True": ) handlers[FileType.IMAGE] = ImageCaptioning("cuda") -swarms = Swarms(api_key) +agent_manager = AgentManager.create(toolsets=toolsets) file_handler = FileHandler(handlers=handlers, path=BASE_DIR) templates = Jinja2Templates(directory=BASE_DIR / "api" / "templates") -uploader = StaticUploader( - static_dir=BASE_DIR / "static", - endpoint="static", - public_url=os.getenv("PUBLIC_URL") +uploader = StaticUploader.from_settings( + path=BASE_DIR / "static", endpoint="static" ) -reload_dirs = [BASE_DIR / "swarms", BASE_DIR / "api"] +reload_dirs = [BASE_DIR / "core", BASE_DIR / "api"] \ No newline at end of file diff --git a/swarms/utils/static.py b/swarms/utils/static.py new file mode 100644 index 00000000..7b642857 --- /dev/null +++ b/swarms/utils/static.py @@ -0,0 +1,28 @@ +import os +import shutil +from pathlib import Path + +# from env import DotEnv + +from swarms.utils.utils import AbstractUploader + +class StaticUploader(AbstractUploader): + def __init__(self, server: str, path: Path, endpoint: str): + self.server = server + self.path = path + self.endpoint = endpoint + + @staticmethod + def from_settings(path: Path, endpoint: str) -> "StaticUploader": + return StaticUploader(os.environ["SERVER"], path, endpoint) + + def get_url(self, uploaded_path: str) -> str: + return f"{self.server}/{uploaded_path}" + + def upload(self, filepath: str): + relative_path = Path("generated") / filepath.split("/")[-1] + file_path = self.path / relative_path + os.makedirs(os.path.dirname(file_path), exist_ok=True) + shutil.copy(filepath, file_path) + endpoint_path = self.endpoint / relative_path + return f"{self.server}/{endpoint_path}" \ No newline at end of file