| """ |
| 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: |
| 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() |
|
|