Commit 5c613cc
committed
feat: argon2id memory-hard PoW, key rotation with chain continuity, pre-rotation commitments
Add Argon2id proof-of-work with SHA-256 pre-filter (12-bit) for
GPU-farm resistance. Three server-assigned presets (light/standard/
hardened) with bounded verification concurrency via semaphore.
Implement rotation_chain_id (SHA-256 of first public key) linking
successive DIDs across key rotations. Trust scores, rate limits,
and fingerprints follow the chain, not individual DIDs. First-write-
wins prevents fork attacks on the rotation endpoint.
Add KERI-inspired pre-rotation commitment: agents commit SHA-256 of
their next public key before rotation. Mandatory from Tier 1, with
72-hour update lockout to prevent attacker overwrite.
New endpoints: POST /rotate-key, POST /pre-commit-key.
New package: airlock/rotation/ (chain registry + precommit).
68 new tests (601 → 669 total).1 parent 28414ad commit 5c613cc
18 files changed
Lines changed: 2440 additions & 44 deletions
File tree
- airlock
- gateway
- reputation
- rotation
- schemas
- semantic
- tests
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
130 | 130 | | |
131 | 131 | | |
132 | 132 | | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
133 | 140 | | |
134 | 141 | | |
135 | 142 | | |
| |||
163 | 170 | | |
164 | 171 | | |
165 | 172 | | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
| 182 | + | |
166 | 183 | | |
167 | 184 | | |
168 | 185 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
29 | 29 | | |
30 | 30 | | |
31 | 31 | | |
| 32 | + | |
| 33 | + | |
32 | 34 | | |
33 | 35 | | |
34 | 36 | | |
| |||
49 | 51 | | |
50 | 52 | | |
51 | 53 | | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
52 | 65 | | |
53 | 66 | | |
54 | 67 | | |
| |||
189 | 202 | | |
190 | 203 | | |
191 | 204 | | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
192 | 218 | | |
193 | 219 | | |
194 | 220 | | |
| |||
0 commit comments