import orjson as json, math
from config import CFG
from pam.rdp import rdp_gaussian, rdp_to_eps

def load(path:str):
    with open(path,"rb") as f: return json.loads(f.read())

def recompute_router_eps(ledger:dict):
    sigmas=[e["sigma"] for e in ledger.get("per_edge",[])]
    if not sigmas: return (0.0, None)
    best=(float("inf"),None)
    for a in CFG.RDP_ORDERS:
        eps = rdp_to_eps(sum(rdp_gaussian(a,s) for s in sigmas), a, CFG.DELTA)
        if eps < best[0]: best=(eps,a)
    return best

def kappa_stats(ledger:dict):
    """Compute κ = log(N/Nub) stats from N_records."""
    ks=[]
    for nid, N, Nub in ledger.get("N_records", []):
        if N>0 and Nub>0:
            ks.append(math.log(N/float(Nub)))
    if not ks: return {"mean_kappa": 0.0, "neg_frac": 0.0, "count": 0}
    neg = sum(1 for x in ks if x<0)/len(ks)
    return {"mean_kappa": sum(ks)/len(ks), "neg_frac": neg, "count": len(ks)}

def validate(path:str) -> dict:
    L = load(path)
    eps,a = recompute_router_eps(L)
    logged = L.get("router_rdp_eps", None)
    ok_eps = (logged is None and not L.get("per_edge")) or (logged is not None and abs(float(logged)-eps)<1e-6)
    return {
        "ok_eps": ok_eps, "eps_recomputed": eps, "alpha": a,
        "mode": L.get("mode"), "claim_type": L.get("claim_type"),
        "privacy_scope": L.get("privacy_scope"),
        "guards": L.get("guards", []),
        "kappa": kappa_stats(L),
    }
