Tice / server /app.py
fierce74's picture
Upload folder using huggingface_hub
cc6e5ac verified
"""
FastAPI application for the TICE environment.
This module creates an HTTP server that exposes `TICEEnvironment` over HTTP and WebSocket
endpoints, compatible with OpenEnv `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
"""
try:
from openenv.core.env_server.http_server import create_app
except Exception as e: # pragma: no cover
raise ImportError(
"openenv is required for the web interface. Install dependencies with '\n uv sync\n'"
) from e
try:
from ..models import TICEAction, TICEObservation
from .tice_environment import TICEEnvironment
except (ImportError, ModuleNotFoundError):
from models import TICEAction, TICEObservation
from server.tice_environment import TICEEnvironment
app = create_app(
TICEEnvironment,
TICEAction,
TICEObservation,
env_name="tice",
max_concurrent_envs=4,
)
def main(host: str = "0.0.0.0", port: int = 8000) -> None:
"""
Entry point for direct execution via `python -m server.app`.
For production deployments, prefer calling uvicorn directly with multiple workers:
uvicorn server.app:app --workers 4
"""
import argparse
import uvicorn
parser = argparse.ArgumentParser()
parser.add_argument("--host", type=str, default=host)
parser.add_argument("--port", type=int, default=port)
args = parser.parse_args()
uvicorn.run(app, host=args.host, port=args.port)
if __name__ == "__main__":
main()