ncncomplete's picture
Upload folder using huggingface_hub
d145b94 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 Coding Environment.
This module creates an HTTP server that exposes the PythonCodeActEnv
over HTTP and WebSocket endpoints, compatible with EnvClient.
Usage:
# Development (with auto-reload):
uvicorn envs.coding_env.server.app:app --reload --host 0.0.0.0 --port 8000
# Production:
uvicorn envs.coding_env.server.app:app --host 0.0.0.0 --port 8000 --workers 4
# Or run directly:
python -m envs.coding_env.server.app
"""
from fastapi import Query
try:
from coding_env.models import CodeAction, CodeObservation
from coding_env.server.python_codeact_env import PythonCodeActEnv
from coding_env.server.task_bank import get_episode_score, list_tasks
except ImportError:
from ..models import CodeAction, CodeObservation
from .python_codeact_env import PythonCodeActEnv
from .task_bank import get_episode_score, list_tasks
from openenv.core.env_server import create_app
# Create the app with web interface and README integration
# Pass the class (factory) instead of an instance for WebSocket session support
app = create_app(PythonCodeActEnv, CodeAction, CodeObservation, env_name="coding_env")
@app.get("/tasks", tags=["Environment Info"])
def tasks():
"""Return available benchmark tasks and their difficulty."""
return {"tasks": list_tasks()}
@app.get("/grader", tags=["Environment Info"])
def grader(
task_id: str = Query(..., description="Task identifier"),
episode_id: str = Query(..., description="Episode identifier"),
):
"""Return normalized score in [0.0, 1.0] for task/episode."""
score = get_episode_score(task_id, episode_id)
return {"task_id": task_id, "episode_id": episode_id, "score": float(score)}
if __name__ == "__main__":
import uvicorn
uvicorn.run(app, host="0.0.0.0", port=8000)
def main():
"""Main entry point for running the server."""
import uvicorn
uvicorn.run(app, host="0.0.0.0", port=8000)
if __name__ == "__main__":
main()