Spaces:
Running on A10G
Running on A10G
File size: 1,784 Bytes
95cbc5b | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 | from __future__ import annotations
from dataclasses import dataclass, field
from typing import Literal, Optional
ActionType = Literal["request_context", "analyze", "verdict"]
@dataclass(frozen=True, slots=True)
class CommitGuardAction:
action_type: ActionType
file_path: Optional[str] = None
reasoning: Optional[str] = None
is_vulnerable: Optional[bool] = None
vuln_type: Optional[str] = None
exploit_sketch: Optional[str] = None
raw_action: Optional[str] = None
parse_error: Optional[str] = None
@dataclass(frozen=True, slots=True)
class ContextSnippet:
file_path: str
start_line: int
end_line: int
content: str
@dataclass(frozen=True, slots=True)
class CommitGuardObservation:
# Cheating-prevention critical: this shape must never include ground truth.
episode_id: str
step_idx: int
diff: str
available_files: list[str]
context_snippets: list[ContextSnippet] = field(default_factory=list)
budget_remaining: int = 0
error: Optional[str] = None
@dataclass(frozen=True, slots=True)
class CommitGuardState:
episode_id: str
current_sample_id: str
step_count: int
context_requests: int = 0
history: list[dict] = field(default_factory=list)
@dataclass(frozen=True, slots=True)
class DevignSample:
sample_id: str
diff: str
available_files: list[str]
# Server-only fields (must never be surfaced in Observation)
is_vulnerable: Optional[bool] = None
cwe: Optional[str] = None
target_file: Optional[str] = None
files: Optional[dict[str, str]] = None
@dataclass(frozen=True, slots=True)
class ScanResult:
is_vulnerable: bool
cwe: Optional[str]
exploit_sketch: Optional[str]
raw_response: str
parse_error: Optional[str] = None
|