|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
""" |
|
|
FastAPI application for the Tbench2 Env Environment. |
|
|
|
|
|
This module creates an HTTP server that exposes the Tbench2Environment |
|
|
over HTTP and WebSocket endpoints, compatible with EnvClient. |
|
|
|
|
|
Endpoints: |
|
|
- POST /reset: Reset the environment |
|
|
- POST /step: Execute an action |
|
|
- GET /state: Get current environment state |
|
|
- GET /schema: Get action/observation schemas |
|
|
- WS /ws: WebSocket endpoint for persistent sessions |
|
|
|
|
|
Usage: |
|
|
# Development (with auto-reload): |
|
|
uvicorn server.app:app --reload --host 0.0.0.0 --port 8000 |
|
|
|
|
|
# Production: |
|
|
uvicorn server.app:app --host 0.0.0.0 --port 8000 --workers 4 |
|
|
|
|
|
# Or run directly: |
|
|
python -m server.app |
|
|
""" |
|
|
|
|
|
import os |
|
|
|
|
|
|
|
|
try: |
|
|
from openenv.core.env_server.http_server import create_app |
|
|
|
|
|
|
|
|
from tbench2_env.models import Tbench2Action, Tbench2Observation |
|
|
|
|
|
from .tbench2_env_environment import Tbench2DockerEnvironment, Tbench2Environment |
|
|
except Exception as e: |
|
|
|
|
|
from openenv.core.env_server.http_server import create_app |
|
|
from server.tbench2_env_environment import Tbench2DockerEnvironment, Tbench2Environment |
|
|
|
|
|
from models import Tbench2Action, Tbench2Observation |
|
|
|
|
|
_IMPORT_ERROR = e |
|
|
|
|
|
|
|
|
|
|
|
_TB2_MODE = os.getenv("TB2_MODE", "local").lower() |
|
|
|
|
|
if _TB2_MODE == "docker": |
|
|
_DEFAULT_ENVIRONMENT = Tbench2DockerEnvironment |
|
|
_ENV_SUFFIX = " (Docker mode)" |
|
|
elif _TB2_MODE == "auto": |
|
|
|
|
|
_DEFAULT_ENVIRONMENT = Tbench2Environment |
|
|
_ENV_SUFFIX = " (auto-detect mode)" |
|
|
else: |
|
|
_DEFAULT_ENVIRONMENT = Tbench2Environment |
|
|
_ENV_SUFFIX = " (local mode)" |
|
|
|
|
|
|
|
|
|
|
|
app = create_app( |
|
|
_DEFAULT_ENVIRONMENT, |
|
|
Tbench2Action, |
|
|
Tbench2Observation, |
|
|
env_name="tbench2_env" + _ENV_SUFFIX, |
|
|
max_concurrent_envs=1, |
|
|
) |
|
|
|
|
|
|
|
|
def main(host: str = "0.0.0.0", port: int = 8000): |
|
|
""" |
|
|
Entry point for direct execution via uv run or python -m. |
|
|
|
|
|
This function enables running the server without Docker: |
|
|
uv run --project . server |
|
|
uv run --project . server --port 8001 |
|
|
python -m tbench2_env.server.app |
|
|
|
|
|
Args: |
|
|
host: Host address to bind to (default: "0.0.0.0") |
|
|
port: Port number to listen on (default: 8000) |
|
|
|
|
|
For production deployments, consider using uvicorn directly with |
|
|
multiple workers: |
|
|
uvicorn tbench2_env.server.app:app --workers 4 |
|
|
""" |
|
|
import uvicorn |
|
|
|
|
|
uvicorn.run(app, host=host, port=port) |
|
|
|
|
|
|
|
|
if __name__ == "__main__": |
|
|
import argparse |
|
|
|
|
|
parser = argparse.ArgumentParser() |
|
|
parser.add_argument("--port", type=int, default=8000) |
|
|
args = parser.parse_args() |
|
|
main(port=args.port) |
|
|
|