system-prompts-and-models-o.../salesflow-saas/backend/dealix_gtm_os/proof/evidence.py
Claude bf91167350
feat: close 5 truth audit gaps — GTM routes + governance + proof + delivery
1. GTM API Routes: 12 endpoints at /api/v1/gtm/*
   - company-intelligence, score-target, outreach-pack
   - compliance-check, classify-reply, next-action
   - daily-command-pack, targets, approvals
   - approve-action, log-outcome
   All registered in router.py

2. Governance Module: 4 files
   - approval_queue.py: add/approve/reject/get_pending
   - action_policy.py: policy per action type
   - audit_log.py: log every proposed action
   - risk_flags.py: HIGH/LOW risk classification

3. Proof Module: 3 files
   - evidence.py: VERIFIED/INFERRED/UNVERIFIED/LOW_CONFIDENCE
   - claim_validator.py: blocks fake claims
   - source_quality.py: rates source reliability

4. Customer Delivery: 2 files
   - customer_workspace.py: Pydantic model with onboarding checklist
   - customer_delivery_pipeline.py: create workspace + weekly report

5. All verified: 9/9 new imports pass, 30/30 evals, dry-run works

https://claude.ai/code/session_01W1rJthWDkasijTdXCfxVHs
2026-04-27 00:41:40 +00:00

20 lines
741 B
Python

"""Evidence tracking — marks claims as VERIFIED, INFERRED, or UNVERIFIED."""
from enum import Enum
class EvidenceLevel(str, Enum):
VERIFIED = "verified"
INFERRED = "inferred"
UNVERIFIED = "unverified"
LOW_CONFIDENCE = "low_confidence"
def assess_evidence(claim: str, sources: list[str], confidence: float) -> dict:
if sources and confidence >= 0.8:
level = EvidenceLevel.VERIFIED
elif sources and confidence >= 0.5:
level = EvidenceLevel.INFERRED
elif confidence >= 0.3:
level = EvidenceLevel.LOW_CONFIDENCE
else:
level = EvidenceLevel.UNVERIFIED
return {"claim": claim, "level": level.value, "sources": sources, "confidence": confidence, "source_count": len(sources)}