Utkarsh Sinha
OpenEnv Customer Support Triage
084325c
from typing import Dict
from openenv.core.client_types import StepResult
from openenv.core.env_server.types import State
from openenv.core import EnvClient
from models import CustomerSupportAction, CustomerSupportObservation
class CustomerSupportEnv(EnvClient[CustomerSupportAction, CustomerSupportObservation, State]):
def _step_payload(self, action: CustomerSupportAction) -> Dict:
return {
"action_type": action.action_type,
"department": action.department,
"priority": action.priority,
"reply_text": action.reply_text,
"escalation_reason": action.escalation_reason,
}
def _parse_result(self, payload: Dict) -> StepResult[CustomerSupportObservation]:
obs_data = payload.get("observation", {})
metadata = obs_data.get("metadata", {})
observation = CustomerSupportObservation(
active_ticket_id=obs_data.get("active_ticket_id"),
ticket_content=obs_data.get("ticket_content"),
ticket_metadata=obs_data.get("ticket_metadata", {}),
unresolved_count=obs_data.get("unresolved_count", 0),
available_departments=obs_data.get("available_departments", []),
available_priorities=obs_data.get("available_priorities", []),
step_count=obs_data.get("step_count", 0),
tickets_summary=obs_data.get("tickets_summary", []),
metadata=metadata
)
return StepResult(
observation=observation,
reward=payload.get("reward", 0.0),
done=payload.get("done", False)
)
def _parse_state(self, payload: Dict) -> State:
return State(
episode_id=payload.get("episode_id"),
step_count=payload.get("step_count", 0),
)