2023-04-16 18:08:16 +00:00
|
|
|
from __future__ import annotations
|
|
|
|
|
2023-04-16 16:52:22 +00:00
|
|
|
import os
|
|
|
|
from pathlib import Path
|
|
|
|
|
2023-04-18 23:54:38 +00:00
|
|
|
from autogpt.config import Config
|
|
|
|
|
|
|
|
CFG = Config()
|
|
|
|
|
2023-04-16 16:52:22 +00:00
|
|
|
# Set a dedicated folder for file I/O
|
|
|
|
WORKSPACE_PATH = Path(os.getcwd()) / "auto_gpt_workspace"
|
|
|
|
|
|
|
|
# Create the directory if it doesn't exist
|
|
|
|
if not os.path.exists(WORKSPACE_PATH):
|
|
|
|
os.makedirs(WORKSPACE_PATH)
|
|
|
|
|
|
|
|
|
|
|
|
def path_in_workspace(relative_path: str | Path) -> Path:
|
|
|
|
"""Get full path for item in workspace
|
|
|
|
|
|
|
|
Parameters:
|
|
|
|
relative_path (str | Path): Path to translate into the workspace
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
Path: Absolute path for the given path in the workspace
|
|
|
|
"""
|
|
|
|
return safe_path_join(WORKSPACE_PATH, relative_path)
|
|
|
|
|
|
|
|
|
|
|
|
def safe_path_join(base: Path, *paths: str | Path) -> Path:
|
|
|
|
"""Join one or more path components, asserting the resulting path is within the workspace.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
base (Path): The base path
|
|
|
|
*paths (str): The paths to join to the base path
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
Path: The joined path
|
|
|
|
"""
|
2023-04-19 18:58:14 +00:00
|
|
|
base = base.resolve()
|
2023-04-16 16:52:22 +00:00
|
|
|
joined_path = base.joinpath(*paths).resolve()
|
|
|
|
|
2023-04-18 23:54:38 +00:00
|
|
|
if CFG.restrict_to_workspace and not joined_path.is_relative_to(base):
|
2023-04-17 20:47:38 +00:00
|
|
|
raise ValueError(
|
2023-04-18 23:54:38 +00:00
|
|
|
f"Attempted to access path '{joined_path}' outside of workspace '{base}'."
|
2023-04-17 20:47:38 +00:00
|
|
|
)
|
2023-04-16 16:52:22 +00:00
|
|
|
|
|
|
|
return joined_path
|