Some checks failed
Test / test (push) Has been cancelled
Cross-platform vectors / TypeScript vectors (bun) (push) Has been cancelled
Cross-platform vectors / Kotlin vectors (gradle) (push) Has been cancelled
Docker build and publish / docker (push) Has been cancelled
Publish / publish (push) Has been cancelled
V3.1 → V3.12 consolidated and tagged for the first GA release. Wire format unchanged from 0.4.x — 4.0 peers interoperate with 0.4.x peers byte-for-byte. The version bump is semantic: audit-cycle complete, opt-in surface fully exposed, threat model refreshed for every new surface. Highlights: - All 24 @shade/* packages bumped to 4.0.0 in lockstep. - CHANGELOG 4.0.0 section is the canonical manifest of what landed. - THREAT-MODEL extended (§10 fingerprint gates, §11 WebRTC P2P, §12 Web-Worker boundary) + residual-risks table refreshed. - OpenAPI now covers all 27 routes: prekey, transfer, KT, inbox, bridge, observer, /metrics, /healthz, /ready. - MIGRATION 0.3.x → 4.0 documented + smoke-tested against shade migrate-storage on a real SQLite DB. - docs/audit/REVIEW-BUNDLE.md + SCOPE.md ready for external reviewer. - scripts/soak.ts harness for the GA-stable 2-week soak window. - All V*.md plans archived under docs/archive/ with Status: Done. - Voice/Video carved out into V5.0; 4.0 audit focuses on the frozen non-realtime stack. Tests: TS 1000/1000 + Kotlin 11/11 cross-platform vectors green. Docker: gt.zyon.no/stian/shade-prekey:4.0.0 builds and reports version 4.0.0 on /health. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
4.0 KiB
4.0 KiB
Shade V3.5 — Android Parity & Cross-Platform CI
Status: Done (kryptografisk lag + CI-gate). Android-KeystoreStorage og scrypt/argon2id-paritet er post-GA-arbeid sporet i android/shade-android/ROADMAP-ANDROID.md — ikke en 4.0 GA-blocker.
Effort: XL (2–4 måneder, parallelliserbar)
Forrige: V3.1
Adresserer: V2.1 §3
Mål
Gjør Kotlin-implementasjonen byte-kompatibel med TS-implementasjonen, og forsegle paritet via CI-gate som kjører delte test-vectors i begge språk. Ingen "production"-label på Android før ratchet + proto + streams 0x11 er grønne.
Scope
Inn — paritet-sjekkpunkter (eksplisitt)
- KDF-chain — root key + chain key derivasjoner.
Vector:
test-vectors/kdf-chain.json. - HKDF — labels for
info-felt. Vector:test-vectors/hkdf.json. - X3DH — full agreement med samme bundles.
Vector:
test-vectors/x3dh.json. - Ratchet message — encrypt/decrypt roundtrip (legg til vector).
- Fingerprint — 60-digit safety number.
Vector:
test-vectors/fingerprint.json. - Wire format 0x02 — encode/decode.
Vector:
test-vectors/wire-format.json. - Streams 0x11 — multi-lane chunk encryption (M-Cross 3, ikke i M-Cross 1).
- Backup-format — passphrase-basert KDF + AES-GCM payload.
Inn — milestoner
- M-Cross 1 ✅ — keys + HKDF + X3DH + fingerprint.
- M-Cross 2 ✅ — ratchet step (encrypt + decrypt roundtrip) + wire 0x02
(RatchetMessage + PreKeyMessage med/uten OTPK). Vector-versjon
2. - M-Cross 3 ✅ — streams 0x11 (KDF, deterministic chunk nonce/AAD, wire 0x11 encode/decode). End-to-end socket interop pending; ikke gating-blokker.
- M-Cross 4 ✅ — backup-format HKDF + AEAD, gruppe sender-keys (kdfChainKey + Ed25519 sign(aad ‖ ct)), storage-HKDF (storageKey, fieldKey, rowNonce). Gjenstående: scrypt master-key (Bouncy Castle), argon2id-bytte, Android-KeystoreStorage som søsken-modul.
Inn — CI
- Gitea Actions matrix-job:
- Bun-runner kjører
bun test:vectorsmottest-vectors/*.json. - Gradle-runner kjører
./gradlew vectorTestsmot samme filer. - PR-gate: begge må passere.
- Bun-runner kjører
- Vector-genereringsskript (
scripts/generate-vectors.ts) finnes — utvid til 7 + 8.
Ut
- iOS — egen Swift-port er framtidig roadmap, ikke V3.5.
- Native bindings i
shade-android(vi bruker Tink i JVM-kode).
Leveranser
Kotlin
- Full ratchet-implementasjon (M-Cross 2).
- Wire 0x02 encode/decode.
- Streams 0x11 (M-Cross 3).
- Tink-storage-adapter med Keystore.
Test-vectors
- Utvid
scripts/generate-vectors.tsmed ratchet-step + streams + backup. - Versjons-tag på vector-filer (
{ "version": 2, ... }).
CI
.gitea/workflows/cross-vectors.yml— Bun + Gradle matrise.- Fail-policy: hvis vector-fil endres, begge runners må publisere passing før merge.
Dokumentasjon
android/shade-android/ROADMAP-ANDROID.md— eksplisitte milestoner + status per sjekkpunkt.docs/cross-platform.md— hvordan legge til en ny vector + hvordan kjøre lokalt.
Akseptansekriterier
- M-Cross 2: TS-encrypted melding kan dekrypteres av Kotlin-klient og omvendt, end-to-end-test.
- CI-jobben feiler innen 60 s ved bevisst byte-divergens.
- M-Cross 3: 1 MiB streams-fil over 4 lanes mellom TS-server og Kotlin-klient verifisert.
- Ingen public release med "production"-label før M-Cross 2 er grønn.
Avhengigheter
- V3.1 —
cross-platform.mdlever der.
Risiko
- Tink-mismatch. Tink HKDF-info-encoding kan avvike fra
@noble/hashes. Mitiger med tidlig vector-test (M-Cross 1 dekker dette). - Endian / encoding. Wire 0x02 bruker big-endian — Kotlin
ByteBufferdefault er big-endian, men streams-nonce-konstruksjon må gjennomgås. - Maintainer-kapasitet. Kotlin-port + TS-port må holdes i sync. Vector-CI er primær mitigasjon.
Migrasjon
Eksisterende M-Cross 1 scaffold beholdes; alt nytt bygges på den.