Delivery sequence numbers (MLS epoch ordering fix):
- schemas/node.capnp: add Envelope{seq,data} struct; enqueue returns seq:UInt64;
fetch/fetchWait return List(Envelope) instead of List(Data)
- storage.rs: Store trait enqueue returns u64; fetch/fetch_limited return
Vec<(u64, Vec<u8>)>; FileBackedStore gains QueueMapV3 with per-inbox seq
counters and V2→V3 on-disk migration
- migrations/002_add_seq.sql: seq column, delivery_seq_counters table, index
- sql_store.rs: atomic UPSERT counter via RETURNING, ORDER BY seq, SCHEMA_VERSION→3
- node_service/delivery.rs: builds Envelope list; returns seq from enqueue
- client/rpc.rs: enqueue→u64, fetch_all/fetch_wait→Vec<(u64,Vec<u8>)>
- client/commands.rs: sort-by-seq before MLS processing; retry loop in cmd_recv
and receive_pending_plaintexts for correct epoch ordering
Server refactor:
- Split monolithic main.rs into node_service/{mod,delivery,auth_ops,key_ops,p2p_ops}
- Add auth.rs (token validation, rate limiting), config.rs, metrics.rs, tls.rs
- Add SQL migrations runner (001_initial.sql, 002_add_seq.sql)
- OPAQUE PAKE login/registration, sealed-sender mode, queue depth limit (1000)
Client refactor:
- Split lib.rs into client/{commands,rpc,state,retry,hex,mod}
- Add cmd_whoami, cmd_health, cmd_check_key, cmd_ping subcommands
- Add cmd_register_user, cmd_login (OPAQUE), cmd_refresh_keypackage
- Hybrid PQ envelope (X25519 + ML-KEM-768) on all send/recv paths
- E2E test suite expanded
Other:
- quicnprotochat-gui: Tauri 2 desktop GUI skeleton (backend + HTML UI)
- quicnprotochat-p2p: iroh-based P2P transport stub
- quicnprotochat-core: app_message, hybrid_crypto modules; GroupMember API updates
- .github/workflows/size-lint.yml: binary size regression check
- docs: protocol comparison, roadmap updates, fully-operational checklist
39 lines
990 B
Bash
39 lines
990 B
Bash
#!/usr/bin/env bash
|
|
set -euo pipefail
|
|
|
|
SOFT_CAP=${SOFT_CAP:-400}
|
|
HARD_CAP=${HARD_CAP:-650}
|
|
warn=0
|
|
fail=0
|
|
ALLOW_FILE=${SIZE_ALLOWLIST:-.size-limits.allow}
|
|
|
|
is_allowed() {
|
|
local file=$1
|
|
[[ -f "$ALLOW_FILE" ]] && grep -Fxq "$file" "$ALLOW_FILE"
|
|
}
|
|
|
|
while IFS= read -r file; do
|
|
lines=$(wc -l <"$file")
|
|
if (( lines > HARD_CAP )); then
|
|
if is_allowed "$file"; then
|
|
printf 'ALLOW (hard cap): %s has %d lines (hard cap %d)\n' "$file" "$lines" "$HARD_CAP"
|
|
warn=1
|
|
continue
|
|
fi
|
|
printf 'FAIL: %s has %d lines (hard cap %d)\n' "$file" "$lines" "$HARD_CAP"
|
|
fail=1
|
|
elif (( lines > SOFT_CAP )); then
|
|
printf 'WARN: %s has %d lines (soft cap %d)\n' "$file" "$lines" "$SOFT_CAP"
|
|
warn=1
|
|
fi
|
|
done < <(git ls-files '*.rs')
|
|
|
|
if (( fail == 1 )); then
|
|
echo "One or more Rust files exceed the hard cap. Please split them before merging."
|
|
exit 1
|
|
fi
|
|
|
|
if (( warn == 1 )); then
|
|
echo "Warnings emitted for files exceeding the soft cap. Consider splitting them."
|
|
fi
|