Step 20: Encryption polish — e2e test, docs, flake.
E2e encryption test: full lifecycle covering init, add encrypted + plaintext, checkpoint, modify, status (no DEK needed), re-checkpoint, restore, verify, re-open with unlock, diff, slot management, passphrase change, old passphrase rejection. Docs updated: - ARCHITECTURE.md: package structure (encrypt.go, encrypt_fido2.go, encrypt CLI), Garden struct (dek field, encryption methods), auth.go descriptions updated for JWT - README.md: encryption commands table, encryption section with usage - CLAUDE.md: added jwt/argon2/chacha20 deps, encryption file mentions flake.nix: vendorHash updated for new deps. Phase 3 complete. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -51,18 +51,19 @@ make proto
|
||||
- `github.com/jonboulle/clockwork` — injectable clock for deterministic tests
|
||||
- `google.golang.org/grpc` — gRPC runtime
|
||||
- `google.golang.org/protobuf` — protobuf runtime
|
||||
- `golang.org/x/crypto` — SSH key auth (ssh, ssh/agent)
|
||||
- `golang.org/x/crypto` — SSH key auth (ssh, ssh/agent), Argon2id, XChaCha20-Poly1305
|
||||
- `github.com/golang-jwt/jwt/v5` — JWT token auth
|
||||
|
||||
## Package Structure
|
||||
|
||||
```
|
||||
cmd/sgard/ CLI entry point (cobra commands, pure wiring)
|
||||
cmd/sgardd/ gRPC server daemon
|
||||
garden/ Core business logic (Garden struct orchestrating everything)
|
||||
garden/ Core business logic (Garden struct, encryption via encrypt.go/encrypt_fido2.go)
|
||||
manifest/ YAML manifest parsing (Manifest/Entry structs, Load/Save)
|
||||
store/ Content-addressable blob storage (SHA-256 keyed)
|
||||
server/ gRPC server (RPC handlers, SSH auth interceptor, proto conversion)
|
||||
client/ gRPC client library (Push, Pull, Prune, SSH credentials)
|
||||
server/ gRPC server (RPC handlers, JWT/SSH auth interceptor, proto conversion)
|
||||
client/ gRPC client library (Push, Pull, Prune, token auth with auto-renewal)
|
||||
sgardpb/ Generated protobuf + gRPC Go code
|
||||
```
|
||||
|
||||
|
||||
Reference in New Issue
Block a user