Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
446 commits
Select commit Hold shift + click to select a range
16c0978
Merge branch 'feature/edgezero-pr13-integration-provider-type-migrati…
prk-Jr Apr 27, 2026
fb8beac
fix cargo fmt
prk-Jr Apr 27, 2026
a94ddd8
resolve PR review findings
prk-Jr Apr 27, 2026
b901037
Added E2E tests dispatch_auth_rejected_401_carries_finalize_headers, …
prk-Jr Apr 27, 2026
2e128f7
Merge feature/edgezero-pr14-entry-point-dual-path into PR15
prk-Jr Apr 27, 2026
f5b7097
fix cargo fmt
prk-Jr Apr 27, 2026
725ccdc
Resolve PR review suggestions
prk-Jr Apr 27, 2026
0dcc750
Resolve PR review findings
prk-Jr Apr 27, 2026
d3138fd
Merge feature/edgezero-pr15-remove-fastly-core into PR16
prk-Jr Apr 27, 2026
6d1184d
Complete PR15 merge and restructure workspace for mixed-target adapters
prk-Jr Apr 28, 2026
b18fd2b
Merge feature/edgezero-pr16-axum-dev-server into PR17
prk-Jr Apr 28, 2026
b99c48f
Resolve PR review findings
prk-Jr Apr 28, 2026
f9a4db0
Resolve PR review findings
prk-Jr Apr 28, 2026
1b9dde3
Add alias for clouflare tests
prk-Jr Apr 28, 2026
4867398
Fix lint error
prk-Jr Apr 28, 2026
9a0d38c
Set default-members to fastly adapter so Viceroy can locate the binary
prk-Jr Apr 29, 2026
e4b4730
Merge feature/edgezero-pr16-axum-dev-server
prk-Jr Apr 29, 2026
76df6f8
Resolve PR review findings
prk-Jr Apr 30, 2026
2a908d4
Merge branch 'main' into feature/edgezero-pr11-utility-layer-migratio…
prk-Jr Apr 30, 2026
65d1e2d
Fix fmt lint
prk-Jr Apr 30, 2026
73734dd
Rename synthetic_id_cookie_value_is_safe → ec_cookie_value_is_safe
prk-Jr Apr 30, 2026
c23663c
Resolve PR review findings
prk-Jr Apr 30, 2026
ca5585c
Merge branch 'feature/edgezero-pr11-utility-layer-migration-v2' into …
prk-Jr Apr 30, 2026
86bd21e
Resolve PR review findings
prk-Jr Apr 30, 2026
9694980
Merge branch 'feature/edgezero-pr12-handler-layer-types' into feature…
prk-Jr Apr 30, 2026
c17fa27
Address PR review findings
prk-Jr Apr 30, 2026
f797f56
Resolve PR 624 review findings
prk-Jr May 12, 2026
e50068e
Merge main into feature/edgezero-pr12-handler-layer-types
prk-Jr May 12, 2026
cd4c621
Call StreamingBody::finish() to properly terminate chunked response
prk-Jr May 12, 2026
e093d01
Apply cargo fmt formatting
prk-Jr May 12, 2026
bf31cca
Resolve PR 626 review findings
prk-Jr May 12, 2026
f360b82
Apply cargo fmt formatting
prk-Jr May 12, 2026
28205a0
Merge feature/edgezero-pr12-handler-layer-types into PR13
prk-Jr May 12, 2026
611c68f
Merge feature/edgezero-pr13-integration-provider-type-migration
prk-Jr May 12, 2026
3cca51c
Address review Non blocker findings
prk-Jr May 12, 2026
50dc61f
Restore EdgeZero consent KV wiring
prk-Jr May 12, 2026
4bb18cb
Merge EdgeZero PR14 updates into PR15 branch
prk-Jr May 12, 2026
978fbb2
Resolve PR review findings and add startup listen log
prk-Jr May 12, 2026
130de76
Merge feature/edgezero-pr15-remove-fastly-core into PR16
prk-Jr May 12, 2026
6574790
Address PR 628 review findings
prk-Jr May 13, 2026
314575b
Fix .gitignore comment: attribute .edgezero/ to upstream framework
prk-Jr May 13, 2026
bff1adc
Remove unused backend.rs — duplicate DEFAULT_FIRST_BYTE_TIMEOUT alrea…
prk-Jr May 13, 2026
ed77810
Resolve PR review findings
prk-Jr May 13, 2026
547c6f1
Merge feature/edgezero-pr16-axum-dev-server and add Cloudflare aliases
prk-Jr May 13, 2026
b4851c4
Fix integration test failure
prk-Jr May 13, 2026
3df4232
Merge branch 'feature/edgezero-pr16-axum-dev-server' into feature/edg…
prk-Jr May 13, 2026
15206b6
Fix cargo clippy fastly
prk-Jr May 13, 2026
189c57c
Update pr review findings
prk-Jr May 14, 2026
6475490
Resolve PR review findings: Axum fallback method parity and stale cli…
prk-Jr May 14, 2026
a499f93
Add Phase 5 verification plan for PR-18
prk-Jr May 20, 2026
ede4e81
Add route smoke tests for all Cloudflare adapter routes
prk-Jr May 20, 2026
acd3f5d
Fix rustfmt formatting in Cloudflare route smoke tests
prk-Jr May 20, 2026
7efa2ff
Add basic-auth parity tests to Axum and Cloudflare adapters
prk-Jr May 20, 2026
69d3693
Fix unwrap_or and comment inconsistency in basic-auth parity tests
prk-Jr May 20, 2026
75fac49
Add admin key route full path coverage to Axum and Cloudflare adapters
prk-Jr May 20, 2026
e891f5e
Tighten storage-fail assertion and add duplicate context comments
prk-Jr May 20, 2026
72be307
Add cross-adapter in-process parity test suite (Axum vs Cloudflare)
prk-Jr May 20, 2026
4f79021
Fix parity test review issues: expect messages, dead if guard, unused…
prk-Jr May 20, 2026
040a77b
Add error-correlation unit tests for PlatformResponse backend_name
prk-Jr May 20, 2026
1e2979d
Add HTML rewriting golden tests, response size check, and Criterion b…
prk-Jr May 20, 2026
0e4d2ea
Add criterion::black_box to benchmark input for measurement purity
prk-Jr May 20, 2026
24f122f
Add cross-adapter parity and benchmark CI gates for Phase 5 verification
prk-Jr May 20, 2026
99967c8
Add inline comment explaining -- --test flag in benchmark CI step
prk-Jr May 20, 2026
8a509ac
Update Cargo.lock files after adding parity test dependencies
prk-Jr May 20, 2026
c114209
Pin axum/tower/tokio versions in integration-tests to match workspace
prk-Jr May 20, 2026
84cbdfe
Pin tokio to exact workspace version =1.52.3 in integration-tests
prk-Jr May 20, 2026
95fde69
Create parent directory before writing build output config
prk-Jr May 20, 2026
0b2228c
Remove redundant wrong-credentials tests from admin key route coverage
prk-Jr May 20, 2026
fdef759
Fix admin_rotate_unauthenticated_parity: assert both adapters return 401
prk-Jr May 20, 2026
5123bd4
Add clippy gate for integration-tests crate in test-parity CI job
prk-Jr May 20, 2026
641bfde
Extract MAX_GROWTH_FACTOR constant in html_processor growth test
prk-Jr May 20, 2026
d7670aa
Fix trailing blank line in Cloudflare routes test file
prk-Jr May 20, 2026
b6a8894
Add clippy component to test-parity toolchain setup
prk-Jr May 20, 2026
a521479
Use multi_thread tokio flavor for all CF adapter route tests
prk-Jr May 20, 2026
5f91da2
Add first-party route smoke tests to Axum adapter
prk-Jr May 20, 2026
c0f2eec
Strengthen parity test assertions for unauthenticated admin routes
prk-Jr May 20, 2026
161c41e
Document tokio exact pin in integration-tests Cargo.toml
prk-Jr May 20, 2026
611fab8
Add canary routing helpers: parse_rollout_pct, fnv1a_bucket, canary_r…
prk-Jr May 21, 2026
5718303
Add pinned FNV-1a test vector and debug_assert for canary bucket range
prk-Jr May 21, 2026
8ef14ec
Add edgezero_rollout_pct canary routing to Fastly entry point
prk-Jr May 21, 2026
8b8c303
Add edgezero_rollout_pct key to local Viceroy config store
prk-Jr May 21, 2026
76aee4a
Add EdgeZero canary rollout ops runbook
prk-Jr May 21, 2026
a1678dc
Warn when edgezero_rollout_pct key is absent (backward-compat full ro…
prk-Jr May 21, 2026
81d5179
Resolve review findings: canary preconditions, missing-IP log, runboo…
prk-Jr May 21, 2026
9c35fbf
Apply rustfmt formatting
prk-Jr May 21, 2026
b30581c
Merge branch 'main' into feature/edgezero-pr12-handler-layer-types
prk-Jr May 21, 2026
0f36454
Generate plan for spin adapter
prk-Jr May 22, 2026
f9e46dd
Resolve PR review findings: Axum/Fastly parity and stale docs
prk-Jr May 22, 2026
a6e1073
Resolve PR review findings: Axum/Fastly parity and stale docs
prk-Jr May 23, 2026
01fd4c1
Tighten the spin adapter integration plan
prk-Jr May 23, 2026
b29b377
Add Fermyon Spin adapter with EdgeZero rev bump and CI
prk-Jr May 25, 2026
89ab20a
Bump worker-build to ^0.8 for worker 0.8 compatibility
prk-Jr May 25, 2026
d5b745d
Reject digit-leading KIDs in validate_kid
prk-Jr May 27, 2026
4c4f1b6
Fix Spin adapter WASI HTTP proxy and variable encoding
prk-Jr May 27, 2026
951a35c
Merge branch 'feature/edgezero-pr19-spin-adapter' into feature/edgeze…
prk-Jr May 27, 2026
58b754a
Resolve PR 624 round-6 review findings
prk-Jr May 28, 2026
62923fd
Merge branch 'main' into feature/edgezero-pr12-handler-layer-types
prk-Jr May 28, 2026
f551544
Resolve PR 626 round-1 review findings
prk-Jr May 28, 2026
2b17d4c
Merge feature/edgezero-pr12-handler-layer-types into PR13
prk-Jr May 28, 2026
1973b5d
Resolve PR 628 round-1 review findings
prk-Jr May 28, 2026
8a83c5e
Merge feature/edgezero-pr13-integration-provider-type-migration into …
prk-Jr May 28, 2026
72ddc42
Resolve PR 635 round-1 review findings
prk-Jr May 28, 2026
5225c01
Merge feature/edgezero-pr14-entry-point-dual-path into PR15
prk-Jr May 28, 2026
746993c
Resolve PR 643 round-2 review findings
prk-Jr May 28, 2026
5f8397c
Merge feature/edgezero-pr15-remove-fastly-core into PR16
prk-Jr May 28, 2026
ed4e225
Fix missing compat::from_fastly_response conversion in edgezero_main
prk-Jr May 28, 2026
e6206a5
Fix dead code and spurious mut from PR15 merge in main.rs
prk-Jr May 28, 2026
5e278d4
Resolve PR 644 round-4 review findings
prk-Jr May 28, 2026
17655cc
Fix Method::from — worker 0.7 implements From<String> not From<&str>
prk-Jr May 28, 2026
e5a36e8
Add compile_error! for cloudflare feature on non-wasm32 targets
prk-Jr May 28, 2026
31862f5
Collapse 13 handler closures into make_handler factory in app.rs
prk-Jr May 28, 2026
70def67
Resolve PR 725 round-1 review findings
prk-Jr May 28, 2026
bee7a39
Merge feature/edgezero-pr18-phase5-verification into spin adapter branch
prk-Jr May 28, 2026
a214f94
Fix Spin publisher HTML processor bypass caused by missing Host header
prk-Jr May 28, 2026
4d10761
Resolve PR 735 round-1 review findings
prk-Jr May 29, 2026
4e51206
Add Spin adapter to public docs and README
prk-Jr May 29, 2026
dc4a7d7
Fix proxy_rebuild_adds_and_removes_params test after tstoken validation
prk-Jr May 29, 2026
254bd2e
Resolve PR review findings: strengthen test assertions and CI gate
prk-Jr May 29, 2026
36e198c
Fix clippy-spin-native failures in app.rs
prk-Jr May 29, 2026
971a7f5
Bound publisher response body size and document interim buffering
prk-Jr Jun 6, 2026
a2af24a
Merge main into feature/edgezero-pr12-handler-layer-types
prk-Jr Jun 7, 2026
acf775a
Add edge_cookie module, test helpers, and integration handle signatures
prk-Jr Jun 7, 2026
78302a2
Fix remaining code review findings from merge
prk-Jr Jun 7, 2026
c229146
Fix cargo fmt lint
prk-Jr Jun 7, 2026
936e721
Resolve merge conflicts from feature/edgezero-pr12-handler-layer-types
prk-Jr Jun 8, 2026
b71da80
Resolve PR 626 round-2 review findings
prk-Jr Jun 8, 2026
6c4b66c
Resolve merge conflicts between PR14 and PR13
prk-Jr Jun 8, 2026
ed065ba
Resolve PR14 round-1 review findings
prk-Jr Jun 8, 2026
04ca534
Update integration-tests lock file to fix CI --locked failure
prk-Jr Jun 8, 2026
63538f5
Update root workspace lock file to match integration-tests versions
prk-Jr Jun 8, 2026
f31ecbf
Resolve merge conflicts and make PR15 compile cleanly
prk-Jr Jun 8, 2026
98dac49
Update integration-tests lock file for getrandom wasm dep and tokio d…
prk-Jr Jun 8, 2026
cfdaf82
Finish tokio removal from trusted-server-core
prk-Jr Jun 8, 2026
cedea8b
Fix stale fastly::Body doc reference in platform/mod.rs
prk-Jr Jun 8, 2026
1c5882b
Merge feature/edgezero-pr15-remove-fastly-core into PR16 (round 2)
prk-Jr Jun 8, 2026
87bbd25
Remove fastly dependency from core via EcKvStore platform trait
prk-Jr Jun 10, 2026
8841e24
Fix adapter tests broken by strict placeholder-secret validation
prk-Jr Jun 10, 2026
02b0605
Address round-4 review findings on Axum dev server PR
prk-Jr Jun 10, 2026
4a2e113
Update integration-tests lock file after fastly removal from core
prk-Jr Jun 10, 2026
18f171b
Merge feature/edgezero-pr16-axum-dev-server into PR17
prk-Jr Jun 10, 2026
8efccb9
Address Cloudflare adapter review findings and fix axum CI wasm target
prk-Jr Jun 10, 2026
d541bbd
Install wasm32-wasip1 target in test-axum CI job
prk-Jr Jun 10, 2026
d9e7217
Merge branch 'feature/edgezero-pr16-axum-dev-server' into feature/edg…
prk-Jr Jun 10, 2026
0be49bb
Merge feature/edgezero-pr17-cloudflare-adapter into PR18
prk-Jr Jun 10, 2026
40e982b
Merge feature/edgezero-pr18-phase5-verification into PR19
prk-Jr Jun 12, 2026
75d85b0
Fix parity-crate clippy violations and bump worker for worker-build 0.8
prk-Jr Jun 12, 2026
79531d6
Merge remote-tracking branch 'origin/main' into feature/edgezero-pr12…
prk-Jr Jun 12, 2026
4fbafd5
Resolve PR14 round-2 review findings
prk-Jr Jun 12, 2026
726301d
Port EC identity lifecycle and EC API routes to the EdgeZero path
prk-Jr Jun 12, 2026
cc9a2e5
Align shared dependency versions in integration-tests lock file
prk-Jr Jun 12, 2026
f8df5b7
Merge feature/edgezero-pr14-entry-point-dual-path into PR15
prk-Jr Jun 12, 2026
32d37db
Resolve PR15 re-review findings
prk-Jr Jun 12, 2026
711dd6c
Document why trusted-server-core still depends on fastly
prk-Jr Jun 12, 2026
47b746e
Merge feature/edgezero-pr15-remove-fastly-core into PR16
prk-Jr Jun 12, 2026
f7e8846
Resolve PR16 round-5 review findings
prk-Jr Jun 12, 2026
4180b9d
Merge branch 'feature/edgezero-pr16-axum-dev-server' into feature/edg…
prk-Jr Jun 12, 2026
fe9951d
Extend per-target build/check aliases to the Cloudflare adapter
prk-Jr Jun 12, 2026
afecb5d
Strip internal fastly-ssl signal from publisher origin requests
prk-Jr Jun 13, 2026
6db27d9
Merge remote-tracking branch 'origin/feature/edgezero-pr17-cloudflare…
prk-Jr Jun 13, 2026
964834f
Fix clippy violations in integration-tests crate
prk-Jr Jun 13, 2026
a5f0e35
Address Phase 5 verification review findings
prk-Jr Jun 13, 2026
86e6d12
Merge feature/edgezero-pr18-phase5-verification into PR19 spin adapter
prk-Jr Jun 13, 2026
7461d88
Derive trusted host and scheme from spin-full-url on the Spin adapter
prk-Jr Jun 13, 2026
7dd15b5
Route all publisher fallback methods on the Spin adapter
prk-Jr Jun 13, 2026
1d01d14
Reject deleting reserved signing params during proxy-rebuild
prk-Jr Jun 13, 2026
8098617
Keep legacy digit-leading KIDs removable via the admin API
prk-Jr Jun 13, 2026
86893a8
Pin worker-build to the locked worker version in the Cloudflare build
prk-Jr Jun 13, 2026
9743550
Demote absent edgezero_rollout_pct log to debug
prk-Jr Jun 13, 2026
7b420cc
Skip canary hashing for degenerate rollout and rename routing predicate
prk-Jr Jun 13, 2026
30002e2
Add unit tests for read_rollout_pct config-store branches
prk-Jr Jun 13, 2026
cbaa4a1
Clarify canary verification logs require debug-level logging
prk-Jr Jun 13, 2026
44e5b80
Reconstruct absolute request URIs for Spin first-party handlers
prk-Jr Jun 13, 2026
699a49a
Enforce a portable KID contract across signing adapters
prk-Jr Jun 13, 2026
a9e3134
Enforce the Spin response-size ceiling on all response paths
prk-Jr Jun 13, 2026
e346514
Align Spin Host with the trusted URI and expose GET /health
prk-Jr Jun 13, 2026
26e5a26
Exclude the Spin crate from build-fastly and check-fastly
prk-Jr Jun 13, 2026
722c6dc
Extract canary dispatch decision into a testable helper
prk-Jr Jun 13, 2026
08168cb
Merge remote-tracking branch 'origin/feature/edgezero-pr19-spin-adapt…
prk-Jr Jun 13, 2026
3715cf5
Restore std::net::IpAddr import after merge with base
prk-Jr Jun 13, 2026
34e1609
Enforce max_buffered_body_bytes on the buffered publisher post-proces…
prk-Jr Jun 14, 2026
17a339c
Compare discovery body bytes when JSON parse fails in parity test
prk-Jr Jun 14, 2026
0dcd6f6
Drop unauthenticated legacy admin aliases and strip Spin synthetic he…
prk-Jr Jun 14, 2026
d5bcd8a
Drop unauthenticated legacy admin aliases on Cloudflare and Fastly
prk-Jr Jun 14, 2026
b00d742
Merge branch 'feature/edgezero-pr18-phase5-verification' into feature…
prk-Jr Jun 14, 2026
706b077
Make the canary runbook honest about production route observability
prk-Jr Jun 14, 2026
6e191e9
Merge branch 'main' into feature/edgezero-pr12-handler-layer-types
aram356 Jun 14, 2026
cf39f2d
Migrate auction format tests to edgezero http types after merge
prk-Jr Jun 15, 2026
609154e
Merge remote-tracking branch 'origin/feature/edgezero-pr12-handler-la…
prk-Jr Jun 15, 2026
4d57b83
Give auction transport failures a consistent error envelope
prk-Jr Jun 15, 2026
023cb2e
Merge remote-tracking branch 'origin/feature/edgezero-pr13-integratio…
prk-Jr Jun 15, 2026
c869faf
Bound the HTML post-processing accumulator by max_buffered_body_bytes
prk-Jr Jun 15, 2026
eeabc24
Correct max_buffered_body_bytes failure status in sample config
prk-Jr Jun 15, 2026
dab40a6
Assert Cloudflare legacy admin alias absence at the route table
prk-Jr Jun 15, 2026
3e6fbd9
Harden Spin request authority against spoofable headers
prk-Jr Jun 15, 2026
5f81e80
Make Fastly route-decision debug logs observable for local canary val…
prk-Jr Jun 15, 2026
50c9e2e
Merge remote-tracking branch 'origin/main' into feature/edgezero-pr14…
prk-Jr Jun 15, 2026
75ad738
Merge remote-tracking branch 'origin/feature/edgezero-pr14-entry-poin…
prk-Jr Jun 15, 2026
96f2bd6
Sync integration-tests lockfile after dropping core wasm js deps
prk-Jr Jun 15, 2026
36a0ba7
Fix EdgeZero fallback asset-route and EC partner parity
prk-Jr Jun 16, 2026
74c51db
Drop legacy admin aliases on Axum to match Fastly and Cloudflare
prk-Jr Jun 16, 2026
67070e8
Harden Spin client-IP trust and centralize request normalization
prk-Jr Jun 16, 2026
17925a7
Make absent rollout_pct fail safe to legacy and fix canary docs
prk-Jr Jun 16, 2026
403de35
Align stale canary docs with fail-safe absent-key behavior
prk-Jr Jun 16, 2026
a1e108f
Merge remote-tracking branch 'origin/main' into feature/edgezero-pr14…
prk-Jr Jun 17, 2026
9785872
Capture EdgeZero device signals before request conversion
prk-Jr Jun 17, 2026
bb180ff
Preserve origin Content-Length for bodiless EdgeZero asset responses
prk-Jr Jun 17, 2026
b0a57ac
Align Publisher Default with the config buffer-cap default
prk-Jr Jun 17, 2026
19a1070
Merge remote-tracking branch 'origin/feature/edgezero-pr14-entry-poin…
prk-Jr Jun 17, 2026
4a4b4b9
Add trusted-server-adapter-cloudflare crate (PR 17) (#644)
prk-Jr Jun 17, 2026
486e62d
Resolve PR16 round-6 review nitpicks
prk-Jr Jun 17, 2026
12859d5
Merge feature/edgezero-pr15-remove-fastly-core into PR16
prk-Jr Jun 17, 2026
b391b86
Sync integration-tests lockfile after merging PR15
prk-Jr Jun 17, 2026
04c0ebb
Merge feature/edgezero-pr16-axum-dev-server into PR18
prk-Jr Jun 17, 2026
3ab0192
Address PR18 review findings: doc drift and test domains
prk-Jr Jun 17, 2026
50524fa
Pin worker-build to the 0.7 series for the Cloudflare local build
prk-Jr Jun 17, 2026
ba07d4b
Run integration request filters on the EdgeZero entry point
prk-Jr Jun 19, 2026
d44074f
Merge remote-tracking branch 'origin/feature/edgezero-pr14-entry-poin…
prk-Jr Jun 19, 2026
a50d293
Merge remote-tracking branch 'origin/feature/edgezero-pr15-remove-fas…
prk-Jr Jun 19, 2026
958464d
Merge remote-tracking branch 'origin/feature/edgezero-pr16-axum-dev-s…
prk-Jr Jun 19, 2026
70380c2
Deny legacy admin aliases locally instead of proxying them
prk-Jr Jun 19, 2026
cb7b6a0
Force-reinstall worker-build when the local copy is on a stale series
prk-Jr Jun 19, 2026
2c57592
Fix integration-tests clippy and legacy-alias parity for local deny
prk-Jr Jun 19, 2026
3ddc3f4
Merge remote-tracking branch 'origin/feature/edgezero-pr18-phase5-ver…
prk-Jr Jun 19, 2026
76f2207
Build integration-test adapter artifacts with the real EC passphrase
prk-Jr Jun 19, 2026
59c4977
Strip client-supplied X-Forwarded-For on the Spin adapter
prk-Jr Jun 19, 2026
b394581
Do not apply the proxy SSRF allowlist to click-redirect rebuilds
prk-Jr Jun 19, 2026
5afb4fe
Merge remote-tracking branch 'origin/feature/edgezero-pr19-spin-adapt…
prk-Jr Jun 20, 2026
848ca9c
Auto-raise Fastly log level under Viceroy via FASTLY_HOSTNAME
prk-Jr Jun 20, 2026
2e1575a
Filter route-decision debug logs at the outer fern Dispatch
prk-Jr Jun 20, 2026
9a83d17
Align canary docs with FASTLY_HOSTNAME log signal and fix-safe snippet
prk-Jr Jun 20, 2026
254c849
Merge origin/main into feature/edgezero-pr16-axum-dev-server
prk-Jr Jun 22, 2026
7f5c89c
Address Cloudflare adapter review findings
prk-Jr Jun 22, 2026
f7a7721
Pin worker-build to ^0.7 in the Cloudflare dev build
prk-Jr Jun 22, 2026
9ac8205
Merge origin/main into feature/edgezero-pr16-axum-dev-server
prk-Jr Jun 23, 2026
87893e0
Merge feature/edgezero-pr16-axum-dev-server into PR18
prk-Jr Jun 24, 2026
f1da325
Ignore nested Cargo target directories
prk-Jr Jun 24, 2026
5d63db3
Resolve PR review routing feedback
prk-Jr Jun 24, 2026
9b97a9d
Merge feature/edgezero-pr18-phase5-verification into PR19
prk-Jr Jun 24, 2026
f379567
Resolve Spin PR review feedback
prk-Jr Jun 24, 2026
d2c6c02
Merge feature/edgezero-pr19-spin-adapter into cutover canary
prk-Jr Jun 25, 2026
194067b
Resolve cutover canary PR review feedback
prk-Jr Jun 25, 2026
784bf6d
Fix integration workflow duplicate job
prk-Jr Jun 25, 2026
9c2e116
Fix integration workflow duplicate job
prk-Jr Jun 25, 2026
2aa7330
Sync integration test lockfile
prk-Jr Jun 25, 2026
09676b2
Merge branch 'feature/edgezero-pr16-axum-dev-server' into feature/edg…
prk-Jr Jun 25, 2026
262d47d
Merge branch 'feature/edgezero-pr16-axum-dev-server' into feature/edg…
prk-Jr Jun 25, 2026
3cae5e9
Merge branch 'feature/edgezero-pr18-phase5-verification' into feature…
prk-Jr Jun 25, 2026
1f5b31b
Merge branch 'feature/edgezero-pr19-spin-adapter' into feature/edgeze…
prk-Jr Jun 25, 2026
26a5704
Merge branch 'main' into feature/edgezero-pr19-cutover-canary
prk-Jr Jun 29, 2026
d28e036
Set edgezero_rollout_pct to 100 in EdgeZero canary fixture
prk-Jr Jun 29, 2026
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
119 changes: 118 additions & 1 deletion crates/trusted-server-adapter-fastly/src/logging.rs
Original file line number Diff line number Diff line change
Expand Up @@ -16,25 +16,82 @@ fn target_label(target: &str) -> &str {
}
}

/// Environment variable that explicitly overrides the Fastly logger's maximum level.
///
/// Production ships at `Info`. `fastly compute serve`/Viceroy does not propagate
/// arbitrary shell environment variables into the Compute guest, so this override
/// only takes effect where the guest environment is populated deliberately (e.g.
/// the integration-test harness). Routine local validation does not depend on it —
/// see [`init_logger`], which auto-raises the level under Viceroy via the
/// [`LOCAL_HOSTNAME_ENV`] signal. The level stays at the safe default when this
/// variable is unset or unparseable.
const LOG_LEVEL_ENV: &str = "EDGEZERO_LOG_LEVEL";

/// Fastly-provided hostname environment variable, visible to guest code.
///
/// Viceroy (`fastly compute serve`) reports [`LOCAL_HOSTNAME`]; production cache
/// nodes report their real hostname. [`init_logger`] reads it to raise the log
/// level for local route-decision observability without affecting production.
///
/// Fastly-specific by design: this signal exists *because* Compute exposes a
/// guest-visible hostname that is fixed to `localhost` only under the simulator.
/// It must not be copied verbatim into the axum/spin/cloudflare adapters, where
/// it carries no such meaning and would mis-detect the runtime environment.
const LOCAL_HOSTNAME_ENV: &str = "FASTLY_HOSTNAME";

/// Hostname value Viceroy reports for [`LOCAL_HOSTNAME_ENV`] in local runs.
const LOCAL_HOSTNAME: &str = "localhost";

/// Resolves the logger's maximum level from an optional configured value,
/// falling back to `Info` when it is absent or not a recognised level filter.
fn resolve_max_level(configured: Option<&str>) -> log::LevelFilter {
configured
.and_then(|value| value.trim().parse::<log::LevelFilter>().ok())
.unwrap_or(log::LevelFilter::Info)
}

/// Detects the maximum log level from explicit config and the Fastly hostname.
///
/// Explicit `EDGEZERO_LOG_LEVEL` input wins, including values that lower the
/// level. Without an explicit value, Viceroy's `FASTLY_HOSTNAME=localhost`
/// auto-raises local runs to `Debug`; production hostnames and missing hostnames
/// stay at the safe `Info` default.
fn detect_max_level(explicit: Option<&str>, hostname: Option<&str>) -> log::LevelFilter {
let configured = explicit.or_else(|| (hostname == Some(LOCAL_HOSTNAME)).then_some("debug"));
resolve_max_level(configured)
}

/// Initialises the Fastly-backed `fern` logger and installs it as the global logger.
///
/// Log records are forwarded to the `tslog` Fastly endpoint and echoed to stdout.
/// Each line is prefixed with an RFC 3339 timestamp, level, and the final segment
/// of the record's target module path.
///
/// The maximum level defaults to `Info`. Under Viceroy (`fastly compute serve`)
/// it is auto-raised to `debug` so route-decision lines are observable locally,
/// detected via the [`LOCAL_HOSTNAME_ENV`] signal. An explicit [`LOG_LEVEL_ENV`]
/// value takes precedence where the guest environment is populated — the value is
/// used as-is, so `error`/`off` lowers it just as `debug` raises it; see
/// [`resolve_max_level`].
///
/// # Panics
///
/// Panics if the Fastly logger cannot be built or if the global logger has already
/// been set.
pub(crate) fn init_logger() {
let explicit = std::env::var(LOG_LEVEL_ENV).ok();
let hostname = std::env::var(LOCAL_HOSTNAME_ENV).ok();
let max_level = detect_max_level(explicit.as_deref(), hostname.as_deref());

let logger = Logger::builder()
.default_endpoint("tslog")
.echo_stdout(true)
.max_level(log::LevelFilter::Info)
.max_level(max_level)
.build()
.expect("should build Logger");

fern::Dispatch::new()
.level(max_level)
.format(|out, message, record| {
out.finish(format_args!(
"{} {} [{}] {}",
Expand Down Expand Up @@ -77,4 +134,64 @@ mod tests {
"should strip separator when trailing segment is empty"
);
}

#[test]
fn resolve_max_level_defaults_to_info_when_unset() {
assert_eq!(
resolve_max_level(None),
log::LevelFilter::Info,
"should default to Info when the override is unset"
);
}

#[test]
fn resolve_max_level_raises_to_debug_for_viceroy_validation() {
assert_eq!(
resolve_max_level(Some("debug")),
log::LevelFilter::Debug,
"should raise to Debug so route-decision lines are observable locally"
);
assert_eq!(
resolve_max_level(Some(" DEBUG ")),
log::LevelFilter::Debug,
"should accept case-insensitive, surrounding-whitespace values"
);
}

#[test]
fn resolve_max_level_falls_back_to_info_on_unrecognised_value() {
assert_eq!(
resolve_max_level(Some("not-a-level")),
log::LevelFilter::Info,
"should keep the safe Info default for an unparseable override"
);
}

#[test]
fn detect_max_level_explicit_override_wins_over_local_hostname() {
assert_eq!(
detect_max_level(Some("error"), Some(LOCAL_HOSTNAME)),
log::LevelFilter::Error,
"explicit override should win over Viceroy auto-debug"
);
}

#[test]
fn detect_max_level_auto_debugs_only_for_viceroy_hostname() {
assert_eq!(
detect_max_level(None, Some(LOCAL_HOSTNAME)),
log::LevelFilter::Debug,
"Viceroy localhost hostname should auto-raise local validation to Debug"
);
assert_eq!(
detect_max_level(None, Some("cache-lax1234-LAX")),
log::LevelFilter::Info,
"production Fastly hostnames must stay at Info"
);
assert_eq!(
detect_max_level(None, None),
log::LevelFilter::Info,
"missing hostname should stay at Info"
);
}
}
Loading
Loading