unity_env / server /app.py
Crashbandicoote2's picture
Upload folder using huggingface_hub
0f53490 verified
# Copyright (c) Meta Platforms, Inc. and affiliates.
# All rights reserved.
#
# This source code is licensed under the BSD-style license found in the
# LICENSE file in the root directory of this source tree.
"""
FastAPI application for the Unity ML-Agents Environment.
This module creates an HTTP server that exposes Unity ML-Agents environments
over HTTP and WebSocket endpoints, compatible with EnvClient.
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 1
# Or run directly:
uv run --project . server
Note: Unity environments are not thread-safe, so use workers=1.
"""
# Support multiple import scenarios
try:
# In-repo imports (when running from OpenEnv repository root)
from openenv.core.env_server.http_server import create_app
from ..models import UnityAction, UnityObservation
from .unity_environment import UnityMLAgentsEnvironment
except ImportError:
# openenv from pip
from openenv.core.env_server.http_server import create_app
try:
# Direct execution from envs/unity_env/ directory
import sys
from pathlib import Path
# Add parent directory to path for direct execution
_parent = str(Path(__file__).parent.parent)
if _parent not in sys.path:
sys.path.insert(0, _parent)
from models import UnityAction, UnityObservation
from server.unity_environment import UnityMLAgentsEnvironment
except ImportError:
try:
# Package installed as unity_env
from unity_env.models import UnityAction, UnityObservation
from unity_env.server.unity_environment import UnityMLAgentsEnvironment
except ImportError:
# Running from OpenEnv root with envs prefix
from envs.unity_env.models import UnityAction, UnityObservation
from envs.unity_env.server.unity_environment import UnityMLAgentsEnvironment
# Create the app with web interface
# Pass the class (factory) instead of an instance for WebSocket session support
app = create_app(
UnityMLAgentsEnvironment,
UnityAction,
UnityObservation,
env_name="unity_env",
)
def main():
"""
Entry point for direct execution via uv run or python -m.
This function enables running the server without Docker:
uv run --project . server
python -m envs.unity_env.server.app
openenv serve unity_env
"""
import uvicorn
# Note: workers=1 because Unity environments are not thread-safe
uvicorn.run(app, host="0.0.0.0", port=8000, workers=1)
if __name__ == "__main__":
main()