generated from coulomb/repo-seed
Fixed and improved token tracking
This commit is contained in:
@@ -1,7 +1,8 @@
|
||||
import uuid
|
||||
from datetime import datetime
|
||||
from typing import Any
|
||||
|
||||
from pydantic import BaseModel, ConfigDict, computed_field
|
||||
from pydantic import BaseModel, ConfigDict, Field, computed_field
|
||||
|
||||
|
||||
class TokenEventCreate(BaseModel):
|
||||
@@ -16,6 +17,19 @@ class TokenEventCreate(BaseModel):
|
||||
ref_type: str | None = None
|
||||
ref_id: str | None = None
|
||||
note: str | None = None
|
||||
created_at: datetime | None = None
|
||||
measurement_kind: str | None = None
|
||||
source_provider: str | None = None
|
||||
source_id: str | None = None
|
||||
source_path: str | None = None
|
||||
source_created_at: datetime | None = None
|
||||
parser_version: str | None = None
|
||||
confidence: float | None = None
|
||||
cached_input_tokens: int | None = None
|
||||
reasoning_output_tokens: int | None = None
|
||||
raw_total_tokens: int | None = None
|
||||
cost_estimated_usd: float | None = None
|
||||
raw_metadata: dict[str, Any] | None = None
|
||||
|
||||
|
||||
class TokenEventRead(BaseModel):
|
||||
@@ -33,6 +47,19 @@ class TokenEventRead(BaseModel):
|
||||
ref_type: str | None = None
|
||||
ref_id: str | None = None
|
||||
note: str | None = None
|
||||
measurement_kind: str
|
||||
source_provider: str
|
||||
source_id: str | None = None
|
||||
source_path: str | None = None
|
||||
source_created_at: datetime | None = None
|
||||
ingested_at: datetime
|
||||
parser_version: str | None = None
|
||||
confidence: float
|
||||
cached_input_tokens: int
|
||||
reasoning_output_tokens: int
|
||||
raw_total_tokens: int | None = None
|
||||
cost_estimated_usd: float | None = None
|
||||
raw_metadata: dict[str, Any] = Field(default_factory=dict)
|
||||
created_at: datetime
|
||||
|
||||
@computed_field
|
||||
@@ -40,6 +67,11 @@ class TokenEventRead(BaseModel):
|
||||
def tokens_total(self) -> int:
|
||||
return self.tokens_in + self.tokens_out
|
||||
|
||||
@computed_field
|
||||
@property
|
||||
def token_evidence_total(self) -> int:
|
||||
return (self.raw_total_tokens or self.tokens_in + self.tokens_out)
|
||||
|
||||
|
||||
class TokenSummary(BaseModel):
|
||||
scope: str
|
||||
@@ -50,14 +82,36 @@ class TokenSummary(BaseModel):
|
||||
event_count: int
|
||||
by_model: dict[str, int]
|
||||
by_agent: dict[str, int]
|
||||
by_measurement_kind: dict[str, int] = Field(default_factory=dict)
|
||||
by_source_provider: dict[str, int] = Field(default_factory=dict)
|
||||
|
||||
|
||||
class TokenEventPatch(BaseModel):
|
||||
tokens_in: int | None = None
|
||||
tokens_out: int | None = None
|
||||
task_id: uuid.UUID | None = None
|
||||
workstream_id: uuid.UUID | None = None
|
||||
repo_id: uuid.UUID | None = None
|
||||
session_id: str | None = None
|
||||
note: str | None = None
|
||||
model: str | None = None
|
||||
agent: str | None = None
|
||||
ref_type: str | None = None
|
||||
ref_id: str | None = None
|
||||
created_at: datetime | None = None
|
||||
measurement_kind: str | None = None
|
||||
source_provider: str | None = None
|
||||
source_id: str | None = None
|
||||
source_path: str | None = None
|
||||
source_created_at: datetime | None = None
|
||||
ingested_at: datetime | None = None
|
||||
parser_version: str | None = None
|
||||
confidence: float | None = None
|
||||
cached_input_tokens: int | None = None
|
||||
reasoning_output_tokens: int | None = None
|
||||
raw_total_tokens: int | None = None
|
||||
cost_estimated_usd: float | None = None
|
||||
raw_metadata: dict[str, Any] | None = None
|
||||
|
||||
|
||||
class RepoTokenSummary(BaseModel):
|
||||
@@ -69,3 +123,49 @@ class RepoTokenSummary(BaseModel):
|
||||
event_count: int
|
||||
by_model: dict[str, int]
|
||||
by_note: dict[str, int]
|
||||
by_measurement_kind: dict[str, int] = Field(default_factory=dict)
|
||||
by_source_provider: dict[str, int] = Field(default_factory=dict)
|
||||
|
||||
|
||||
class TokenAggregateRow(BaseModel):
|
||||
scope_id: str
|
||||
label: str | None = None
|
||||
tokens_in: int
|
||||
tokens_out: int
|
||||
tokens_total: int
|
||||
event_count: int
|
||||
by_measurement_kind: dict[str, int] = Field(default_factory=dict)
|
||||
by_source_provider: dict[str, int] = Field(default_factory=dict)
|
||||
|
||||
|
||||
class TokenAggregateSummary(BaseModel):
|
||||
tokens_in: int
|
||||
tokens_out: int
|
||||
tokens_total: int
|
||||
event_count: int
|
||||
first_event_at: datetime | None = None
|
||||
last_event_at: datetime | None = None
|
||||
last_ingested_at: datetime | None = None
|
||||
by_repo: list[TokenAggregateRow] = Field(default_factory=list)
|
||||
by_workstream: list[TokenAggregateRow] = Field(default_factory=list)
|
||||
by_task: list[TokenAggregateRow] = Field(default_factory=list)
|
||||
by_model: list[TokenAggregateRow] = Field(default_factory=list)
|
||||
by_measurement_kind: dict[str, int] = Field(default_factory=dict)
|
||||
by_source_provider: dict[str, int] = Field(default_factory=dict)
|
||||
|
||||
|
||||
class TokenQualitySummary(BaseModel):
|
||||
event_count: int
|
||||
measured_event_count: int
|
||||
estimated_event_count: int
|
||||
allocated_event_count: int
|
||||
superseded_event_count: int
|
||||
fallback_event_count: int
|
||||
unattributed_measured_event_count: int
|
||||
missing_provenance_event_count: int
|
||||
duplicate_source_count: int
|
||||
last_codex_ingested_at: datetime | None = None
|
||||
last_claude_ingested_at: datetime | None = None
|
||||
last_reconciliation_at: datetime | None = None
|
||||
by_measurement_kind: dict[str, int] = Field(default_factory=dict)
|
||||
by_source_provider: dict[str, int] = Field(default_factory=dict)
|
||||
|
||||
Reference in New Issue
Block a user