# 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 OpenApp Environment. This module creates an HTTP server that exposes the OpenAppEnvironment over HTTP endpoints, making it compatible with HTTPEnvClient. 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: uv run --project . server """ # Support both in-repo and standalone imports try: # In-repo imports (when running from OpenEnv repository) from core.env_server.http_server import create_app from ..models import OpenAppAction, OpenAppObservation from .openapp_environment import OpenAppEnvironment except ImportError: # Standalone imports (when environment is standalone with openenv-core from pip) from openenv_core.env_server.http_server import create_app from openapp_env.models import OpenAppAction, OpenAppObservation from openapp_env.server.openapp_environment import OpenAppEnvironment # Create the environment instance # Use OPENAPPS_URL environment variable if set (Docker mode) # Otherwise, environment will try to auto-launch (not implemented, will fail with helpful error) import os openapps_url = os.environ.get("OPENAPPS_URL") env = OpenAppEnvironment(openapps_url=openapps_url) if openapps_url else OpenAppEnvironment() # Create the app with web interface and README integration app = create_app(env, OpenAppAction, OpenAppObservation, env_name="openapp_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.openapp_env.server.app openenv serve openapp_env """ import uvicorn uvicorn.run(app, host="0.0.0.0", port=8000) if __name__ == "__main__": main()