CodeSecure / client.py
Drac0528's picture
Upload 35 files
8c391c7 verified
from __future__ import annotations
from typing import Dict
try:
from core.client_types import StepResult
from core.env_client import EnvClient
except ImportError:
from openenv.core.client_types import StepResult
from openenv.core.env_client import EnvClient
try:
from .models import CodeSecurityAction, CodeSecurityObservation, CodeSecurityState
except ImportError:
from models import CodeSecurityAction, CodeSecurityObservation, CodeSecurityState
class CodeSecurityAuditorEnv(
EnvClient[CodeSecurityAction, CodeSecurityObservation, CodeSecurityState]
):
"""Client wrapper for the Code Security Auditor environment server."""
def _step_payload(self, action: CodeSecurityAction) -> dict:
payload = {
"action_type": action.action_type,
"confidence": action.confidence,
"evidence": action.evidence,
"summary": action.summary,
}
if action.filename is not None:
payload["filename"] = action.filename
if action.line_start is not None:
payload["line_start"] = action.line_start
if action.line_end is not None:
payload["line_end"] = action.line_end
if action.vuln_type is not None:
payload["vuln_type"] = action.vuln_type
if action.severity is not None:
payload["severity"] = action.severity
return payload
def _parse_result(self, payload: Dict) -> StepResult[CodeSecurityObservation]:
observation = CodeSecurityObservation(**payload.get("observation", {}))
return StepResult(
observation=observation,
reward=payload.get("reward"),
done=bool(payload.get("done", False)),
)
def _parse_state(self, payload: Dict) -> CodeSecurityState:
return CodeSecurityState(**payload)