@timber-js/app 0.2.0-alpha.97 → 0.2.0-alpha.99
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/_chunks/actions-CQ8Z8VGL.js +1061 -0
- package/dist/_chunks/actions-CQ8Z8VGL.js.map +1 -0
- package/dist/_chunks/build-output-helper-DXnW0qjz.js +61 -0
- package/dist/_chunks/build-output-helper-DXnW0qjz.js.map +1 -0
- package/dist/_chunks/{define-Itxvcd7F.js → define-B-Q_UMOD.js} +19 -23
- package/dist/_chunks/define-B-Q_UMOD.js.map +1 -0
- package/dist/_chunks/{define-C77ScO0m.js → define-CfBPoJb0.js} +24 -7
- package/dist/_chunks/define-CfBPoJb0.js.map +1 -0
- package/dist/_chunks/define-cookie-BjpIt4UC.js +194 -0
- package/dist/_chunks/define-cookie-BjpIt4UC.js.map +1 -0
- package/dist/_chunks/{format-CYBGxKtc.js → format-Bcn-Iv1x.js} +1 -1
- package/dist/_chunks/{format-CYBGxKtc.js.map → format-Bcn-Iv1x.js.map} +1 -1
- package/dist/_chunks/handler-store-B-lqaGyh.js +54 -0
- package/dist/_chunks/handler-store-B-lqaGyh.js.map +1 -0
- package/dist/_chunks/logger-0m8MsKdc.js +291 -0
- package/dist/_chunks/logger-0m8MsKdc.js.map +1 -0
- package/dist/_chunks/merge-search-params-BphMdht_.js +122 -0
- package/dist/_chunks/merge-search-params-BphMdht_.js.map +1 -0
- package/dist/_chunks/{metadata-routes-DS3eKNmf.js → metadata-routes-BU684ls2.js} +1 -1
- package/dist/_chunks/{metadata-routes-DS3eKNmf.js.map → metadata-routes-BU684ls2.js.map} +1 -1
- package/dist/_chunks/navigation-root-BCYczjml.js +96 -0
- package/dist/_chunks/navigation-root-BCYczjml.js.map +1 -0
- package/dist/_chunks/registry-I2ss-lvy.js +20 -0
- package/dist/_chunks/registry-I2ss-lvy.js.map +1 -0
- package/dist/_chunks/router-ref-h3-UaCQv.js +28 -0
- package/dist/_chunks/router-ref-h3-UaCQv.js.map +1 -0
- package/dist/_chunks/{schema-bridge-C3xl_vfb.js → schema-bridge-Cxu4l-7p.js} +1 -1
- package/dist/_chunks/{schema-bridge-C3xl_vfb.js.map → schema-bridge-Cxu4l-7p.js.map} +1 -1
- package/dist/_chunks/segment-classify-BjfuctV2.js +137 -0
- package/dist/_chunks/segment-classify-BjfuctV2.js.map +1 -0
- package/dist/_chunks/{segment-context-fHFLF1PE.js → segment-context-Dx_OizxD.js} +1 -1
- package/dist/_chunks/{segment-context-fHFLF1PE.js.map → segment-context-Dx_OizxD.js.map} +1 -1
- package/dist/_chunks/{router-ref-C8OCm7g7.js → ssr-data-B4CdH7rE.js} +2 -26
- package/dist/_chunks/ssr-data-B4CdH7rE.js.map +1 -0
- package/dist/_chunks/{stale-reload-BX5gL1r-.js → stale-reload-Bab885FO.js} +1 -1
- package/dist/_chunks/{stale-reload-BX5gL1r-.js.map → stale-reload-Bab885FO.js.map} +1 -1
- package/dist/_chunks/tracing-C8V-YGsP.js +329 -0
- package/dist/_chunks/tracing-C8V-YGsP.js.map +1 -0
- package/dist/_chunks/{use-query-states-BiV5GJgm.js → use-query-states-B2XTqxDR.js} +3 -19
- package/dist/_chunks/use-query-states-B2XTqxDR.js.map +1 -0
- package/dist/_chunks/{use-params-IOPu7E8t.js → use-segment-params-BkpKAQ7D.js} +9 -95
- package/dist/_chunks/use-segment-params-BkpKAQ7D.js.map +1 -0
- package/dist/_chunks/{interception-BbqMCVXa.js → walkers-Tg0Alwcg.js} +66 -87
- package/dist/_chunks/walkers-Tg0Alwcg.js.map +1 -0
- package/dist/_chunks/{dev-warnings-DpGRGoDi.js → warnings-Cg47l5sk.js} +3 -3
- package/dist/_chunks/warnings-Cg47l5sk.js.map +1 -0
- package/dist/adapters/build-output-helper.d.ts +28 -0
- package/dist/adapters/build-output-helper.d.ts.map +1 -0
- package/dist/adapters/cloudflare.d.ts.map +1 -1
- package/dist/adapters/cloudflare.js +8 -28
- package/dist/adapters/cloudflare.js.map +1 -1
- package/dist/adapters/nitro.d.ts.map +1 -1
- package/dist/adapters/nitro.js +63 -31
- package/dist/adapters/nitro.js.map +1 -1
- package/dist/adapters/shared.d.ts +16 -0
- package/dist/adapters/shared.d.ts.map +1 -0
- package/dist/cache/index.js +9 -2
- package/dist/cache/index.js.map +1 -1
- package/dist/cache/timber-cache.d.ts.map +1 -1
- package/dist/client/error-boundary.js +2 -1
- package/dist/client/error-boundary.js.map +1 -1
- package/dist/client/form.d.ts +10 -24
- package/dist/client/form.d.ts.map +1 -1
- package/dist/client/index.d.ts +1 -5
- package/dist/client/index.d.ts.map +1 -1
- package/dist/client/index.js +41 -91
- package/dist/client/index.js.map +1 -1
- package/dist/client/internal.d.ts +2 -1
- package/dist/client/internal.d.ts.map +1 -1
- package/dist/client/internal.js +81 -7
- package/dist/client/internal.js.map +1 -1
- package/dist/client/rsc-fetch.d.ts.map +1 -1
- package/dist/client/state.d.ts +1 -1
- package/dist/client/use-cookie.d.ts +8 -0
- package/dist/client/use-cookie.d.ts.map +1 -1
- package/dist/client/{use-params.d.ts → use-segment-params.d.ts} +1 -1
- package/dist/client/use-segment-params.d.ts.map +1 -0
- package/dist/codec.d.ts +1 -1
- package/dist/codec.d.ts.map +1 -1
- package/dist/codec.js +2 -2
- package/dist/config-types.d.ts +28 -0
- package/dist/config-types.d.ts.map +1 -1
- package/dist/cookies/define-cookie.d.ts +87 -35
- package/dist/cookies/define-cookie.d.ts.map +1 -1
- package/dist/cookies/index.d.ts +2 -1
- package/dist/cookies/index.d.ts.map +1 -1
- package/dist/cookies/index.js +48 -2
- package/dist/cookies/index.js.map +1 -0
- package/dist/cookies/json-cookie.d.ts +64 -0
- package/dist/cookies/json-cookie.d.ts.map +1 -0
- package/dist/cookies/validation.d.ts +46 -0
- package/dist/cookies/validation.d.ts.map +1 -0
- package/dist/{plugins/dev-404-page.d.ts → dev-tools/404-page.d.ts} +9 -19
- package/dist/dev-tools/404-page.d.ts.map +1 -0
- package/dist/{plugins/dev-browser-logs.d.ts → dev-tools/browser-logs.d.ts} +1 -1
- package/dist/dev-tools/browser-logs.d.ts.map +1 -0
- package/dist/{plugins/dev-error-page.d.ts → dev-tools/error-page.d.ts} +2 -2
- package/dist/dev-tools/error-page.d.ts.map +1 -0
- package/dist/{server/dev-holding-server.d.ts → dev-tools/holding-server.d.ts} +5 -3
- package/dist/dev-tools/holding-server.d.ts.map +1 -0
- package/dist/dev-tools/index.d.ts +31 -0
- package/dist/dev-tools/index.d.ts.map +1 -0
- package/dist/{server/dev-span-processor.d.ts → dev-tools/instrumentation.d.ts} +26 -6
- package/dist/dev-tools/instrumentation.d.ts.map +1 -0
- package/dist/{server/dev-logger.d.ts → dev-tools/logger.d.ts} +1 -1
- package/dist/dev-tools/logger.d.ts.map +1 -0
- package/dist/{plugins/dev-logs.d.ts → dev-tools/logs.d.ts} +1 -1
- package/dist/dev-tools/logs.d.ts.map +1 -0
- package/dist/{plugins/dev-error-overlay.d.ts → dev-tools/overlay.d.ts} +3 -12
- package/dist/dev-tools/overlay.d.ts.map +1 -0
- package/dist/dev-tools/stack-classifier.d.ts +34 -0
- package/dist/dev-tools/stack-classifier.d.ts.map +1 -0
- package/dist/{plugins/dev-terminal-error.d.ts → dev-tools/terminal.d.ts} +2 -2
- package/dist/dev-tools/terminal.d.ts.map +1 -0
- package/dist/{server/dev-warnings.d.ts → dev-tools/warnings.d.ts} +1 -1
- package/dist/dev-tools/warnings.d.ts.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +285 -133
- package/dist/index.js.map +1 -1
- package/dist/plugin-context.d.ts +1 -1
- package/dist/plugin-context.d.ts.map +1 -1
- package/dist/plugins/adapter-build.d.ts.map +1 -1
- package/dist/plugins/build-report.d.ts +6 -4
- package/dist/plugins/build-report.d.ts.map +1 -1
- package/dist/routing/convention-lint.d.ts.map +1 -1
- package/dist/routing/index.d.ts +5 -3
- package/dist/routing/index.d.ts.map +1 -1
- package/dist/routing/index.js +3 -3
- package/dist/routing/scanner.d.ts +1 -10
- package/dist/routing/scanner.d.ts.map +1 -1
- package/dist/routing/segment-classify.d.ts +37 -8
- package/dist/routing/segment-classify.d.ts.map +1 -1
- package/dist/routing/status-file-lint.d.ts.map +1 -1
- package/dist/routing/types.d.ts +63 -23
- package/dist/routing/types.d.ts.map +1 -1
- package/dist/routing/walkers.d.ts +51 -0
- package/dist/routing/walkers.d.ts.map +1 -0
- package/dist/search-params/define.d.ts +25 -7
- package/dist/search-params/define.d.ts.map +1 -1
- package/dist/search-params/index.js +5 -3
- package/dist/search-params/index.js.map +1 -1
- package/dist/search-params/wrappers.d.ts +2 -2
- package/dist/search-params/wrappers.d.ts.map +1 -1
- package/dist/segment-params/define.d.ts +23 -6
- package/dist/segment-params/define.d.ts.map +1 -1
- package/dist/segment-params/index.js +1 -1
- package/dist/server/access-gate.d.ts +4 -3
- package/dist/server/access-gate.d.ts.map +1 -1
- package/dist/server/action-handler.d.ts +15 -6
- package/dist/server/action-handler.d.ts.map +1 -1
- package/dist/server/als-registry.d.ts +5 -5
- package/dist/server/als-registry.d.ts.map +1 -1
- package/dist/server/asset-headers.d.ts +1 -15
- package/dist/server/asset-headers.d.ts.map +1 -1
- package/dist/server/cookie-context.d.ts +170 -0
- package/dist/server/cookie-context.d.ts.map +1 -0
- package/dist/server/cookie-parsing.d.ts +51 -0
- package/dist/server/cookie-parsing.d.ts.map +1 -0
- package/dist/server/deny-boundary.d.ts +90 -0
- package/dist/server/deny-boundary.d.ts.map +1 -0
- package/dist/server/deny-renderer.d.ts.map +1 -1
- package/dist/server/early-hints-sender.d.ts.map +1 -1
- package/dist/server/html-injector-core.d.ts +212 -0
- package/dist/server/html-injector-core.d.ts.map +1 -0
- package/dist/server/html-injectors.d.ts +59 -59
- package/dist/server/html-injectors.d.ts.map +1 -1
- package/dist/server/index.d.ts +5 -4
- package/dist/server/index.d.ts.map +1 -1
- package/dist/server/index.js +4 -149
- package/dist/server/index.js.map +1 -1
- package/dist/server/internal.d.ts +6 -4
- package/dist/server/internal.d.ts.map +1 -1
- package/dist/server/internal.js +852 -852
- package/dist/server/internal.js.map +1 -1
- package/dist/server/logger.d.ts +14 -0
- package/dist/server/logger.d.ts.map +1 -1
- package/dist/server/middleware-runner.d.ts +17 -0
- package/dist/server/middleware-runner.d.ts.map +1 -1
- package/dist/server/node-stream-transforms.d.ts +46 -49
- package/dist/server/node-stream-transforms.d.ts.map +1 -1
- package/dist/server/param-coercion.d.ts +26 -0
- package/dist/server/param-coercion.d.ts.map +1 -0
- package/dist/server/pipeline-helpers.d.ts +95 -0
- package/dist/server/pipeline-helpers.d.ts.map +1 -0
- package/dist/server/pipeline-outcome.d.ts +49 -0
- package/dist/server/pipeline-outcome.d.ts.map +1 -0
- package/dist/server/pipeline-phases.d.ts +52 -0
- package/dist/server/pipeline-phases.d.ts.map +1 -0
- package/dist/server/pipeline.d.ts +51 -32
- package/dist/server/pipeline.d.ts.map +1 -1
- package/dist/server/port-resolution.d.ts +117 -0
- package/dist/server/port-resolution.d.ts.map +1 -0
- package/dist/server/request-context.d.ts +22 -159
- package/dist/server/request-context.d.ts.map +1 -1
- package/dist/server/route-element-builder.d.ts.map +1 -1
- package/dist/server/route-matcher.d.ts +20 -47
- package/dist/server/route-matcher.d.ts.map +1 -1
- package/dist/server/rsc-entry/action-middleware-runner.d.ts +66 -0
- package/dist/server/rsc-entry/action-middleware-runner.d.ts.map +1 -0
- package/dist/server/rsc-entry/helpers.d.ts +1 -1
- package/dist/server/rsc-entry/helpers.d.ts.map +1 -1
- package/dist/server/rsc-entry/index.d.ts.map +1 -1
- package/dist/server/rsc-entry/render-route.d.ts +50 -0
- package/dist/server/rsc-entry/render-route.d.ts.map +1 -0
- package/dist/server/rsc-entry/wrap-action-dispatch.d.ts +119 -0
- package/dist/server/rsc-entry/wrap-action-dispatch.d.ts.map +1 -0
- package/dist/server/state-tree-diff.d.ts.map +1 -1
- package/dist/server/status-code-resolver.d.ts +16 -11
- package/dist/server/status-code-resolver.d.ts.map +1 -1
- package/dist/server/tracing.d.ts +1 -1
- package/dist/server/tracing.d.ts.map +1 -1
- package/dist/server/tree-builder.d.ts +45 -16
- package/dist/server/tree-builder.d.ts.map +1 -1
- package/dist/server/types.d.ts +48 -0
- package/dist/server/types.d.ts.map +1 -1
- package/dist/server/utils/escape-html.d.ts +14 -0
- package/dist/server/utils/escape-html.d.ts.map +1 -0
- package/dist/shims/headers.d.ts +2 -2
- package/dist/shims/headers.d.ts.map +1 -1
- package/dist/shims/navigation-client.d.ts +3 -1
- package/dist/shims/navigation-client.d.ts.map +1 -1
- package/dist/shims/navigation.d.ts +9 -4
- package/dist/shims/navigation.d.ts.map +1 -1
- package/dist/utils/directive-parser.d.ts +0 -45
- package/dist/utils/directive-parser.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/adapters/build-output-helper.ts +77 -0
- package/src/adapters/cloudflare.ts +10 -50
- package/src/adapters/nitro.ts +66 -50
- package/src/adapters/shared.ts +40 -0
- package/src/cache/timber-cache.ts +3 -2
- package/src/client/form.tsx +17 -25
- package/src/client/index.ts +16 -9
- package/src/client/internal.ts +3 -2
- package/src/client/router.ts +1 -1
- package/src/client/rsc-fetch.ts +15 -0
- package/src/client/state.ts +2 -2
- package/src/client/use-cookie.ts +29 -0
- package/src/codec.ts +3 -7
- package/src/config-types.ts +28 -0
- package/src/cookies/define-cookie.ts +271 -78
- package/src/cookies/index.ts +11 -8
- package/src/cookies/json-cookie.ts +105 -0
- package/src/cookies/validation.ts +134 -0
- package/src/{plugins/dev-404-page.ts → dev-tools/404-page.ts} +17 -48
- package/src/{plugins/dev-error-page.ts → dev-tools/error-page.ts} +5 -32
- package/src/{server/dev-holding-server.ts → dev-tools/holding-server.ts} +4 -2
- package/src/dev-tools/index.ts +90 -0
- package/src/dev-tools/instrumentation.ts +176 -0
- package/src/{plugins/dev-logs.ts → dev-tools/logs.ts} +2 -2
- package/src/{plugins/dev-error-overlay.ts → dev-tools/overlay.ts} +5 -23
- package/src/dev-tools/stack-classifier.ts +75 -0
- package/src/{plugins/dev-terminal-error.ts → dev-tools/terminal.ts} +4 -38
- package/src/{server/dev-warnings.ts → dev-tools/warnings.ts} +1 -1
- package/src/index.ts +95 -34
- package/src/plugin-context.ts +1 -1
- package/src/plugins/adapter-build.ts +3 -1
- package/src/plugins/build-report.ts +13 -22
- package/src/plugins/dev-server.ts +3 -3
- package/src/plugins/routing.ts +14 -12
- package/src/plugins/shims.ts +1 -1
- package/src/plugins/static-build.ts +1 -1
- package/src/routing/codegen.ts +1 -1
- package/src/routing/convention-lint.ts +9 -8
- package/src/routing/index.ts +5 -3
- package/src/routing/interception.ts +1 -1
- package/src/routing/scanner.ts +22 -95
- package/src/routing/segment-classify.ts +107 -8
- package/src/routing/status-file-lint.ts +7 -5
- package/src/routing/types.ts +63 -23
- package/src/routing/walkers.ts +90 -0
- package/src/search-params/define.ts +71 -15
- package/src/search-params/wrappers.ts +9 -2
- package/src/segment-params/define.ts +66 -13
- package/src/server/access-gate.tsx +9 -8
- package/src/server/action-handler.ts +34 -38
- package/src/server/als-registry.ts +5 -5
- package/src/server/asset-headers.ts +8 -34
- package/src/server/cookie-context.ts +468 -0
- package/src/server/cookie-parsing.ts +135 -0
- package/src/server/{deny-page-resolver.ts → deny-boundary.ts} +78 -14
- package/src/server/deny-renderer.ts +7 -12
- package/src/server/early-hints-sender.ts +3 -2
- package/src/server/fallback-error.ts +2 -2
- package/src/server/html-injector-core.ts +403 -0
- package/src/server/html-injectors.ts +158 -297
- package/src/server/index.ts +13 -14
- package/src/server/internal.ts +10 -3
- package/src/server/logger.ts +23 -0
- package/src/server/middleware-runner.ts +44 -0
- package/src/server/node-stream-transforms.ts +108 -248
- package/src/server/param-coercion.ts +76 -0
- package/src/server/pipeline-helpers.ts +204 -0
- package/src/server/pipeline-outcome.ts +167 -0
- package/src/server/pipeline-phases.ts +409 -0
- package/src/server/pipeline.ts +70 -540
- package/src/server/port-resolution.ts +215 -0
- package/src/server/request-context.ts +46 -451
- package/src/server/route-element-builder.ts +8 -4
- package/src/server/route-matcher.ts +28 -60
- package/src/server/rsc-entry/action-middleware-runner.ts +167 -0
- package/src/server/rsc-entry/api-handler.ts +2 -2
- package/src/server/rsc-entry/error-renderer.ts +2 -2
- package/src/server/rsc-entry/helpers.ts +2 -7
- package/src/server/rsc-entry/index.ts +81 -366
- package/src/server/rsc-entry/render-route.ts +304 -0
- package/src/server/rsc-entry/rsc-payload.ts +1 -1
- package/src/server/rsc-entry/ssr-renderer.ts +2 -2
- package/src/server/rsc-entry/wrap-action-dispatch.ts +449 -0
- package/src/server/sitemap-generator.ts +1 -1
- package/src/server/slot-resolver.ts +1 -1
- package/src/server/ssr-entry.ts +1 -1
- package/src/server/state-tree-diff.ts +4 -1
- package/src/server/status-code-resolver.ts +112 -128
- package/src/server/tracing.ts +3 -3
- package/src/server/tree-builder.ts +134 -56
- package/src/server/types.ts +52 -0
- package/src/server/utils/escape-html.ts +20 -0
- package/src/shims/headers.ts +3 -3
- package/src/shims/navigation-client.ts +4 -3
- package/src/shims/navigation.ts +9 -7
- package/src/utils/directive-parser.ts +0 -392
- package/dist/_chunks/actions-DLnUaR65.js +0 -421
- package/dist/_chunks/actions-DLnUaR65.js.map +0 -1
- package/dist/_chunks/als-registry-HS0LGUl2.js +0 -41
- package/dist/_chunks/als-registry-HS0LGUl2.js.map +0 -1
- package/dist/_chunks/debug-ECi_61pb.js +0 -108
- package/dist/_chunks/debug-ECi_61pb.js.map +0 -1
- package/dist/_chunks/define-C77ScO0m.js.map +0 -1
- package/dist/_chunks/define-Itxvcd7F.js.map +0 -1
- package/dist/_chunks/define-cookie-BowvzoP0.js +0 -94
- package/dist/_chunks/define-cookie-BowvzoP0.js.map +0 -1
- package/dist/_chunks/dev-warnings-DpGRGoDi.js.map +0 -1
- package/dist/_chunks/interception-BbqMCVXa.js.map +0 -1
- package/dist/_chunks/merge-search-params-Cm_KIWDX.js +0 -41
- package/dist/_chunks/merge-search-params-Cm_KIWDX.js.map +0 -1
- package/dist/_chunks/request-context-CK5tZqIP.js +0 -478
- package/dist/_chunks/request-context-CK5tZqIP.js.map +0 -1
- package/dist/_chunks/router-ref-C8OCm7g7.js.map +0 -1
- package/dist/_chunks/segment-classify-BDNn6EzD.js +0 -65
- package/dist/_chunks/segment-classify-BDNn6EzD.js.map +0 -1
- package/dist/_chunks/tracing-CCYbKn5n.js +0 -238
- package/dist/_chunks/tracing-CCYbKn5n.js.map +0 -1
- package/dist/_chunks/use-params-IOPu7E8t.js.map +0 -1
- package/dist/_chunks/use-query-states-BiV5GJgm.js.map +0 -1
- package/dist/client/use-params.d.ts.map +0 -1
- package/dist/plugins/dev-404-page.d.ts.map +0 -1
- package/dist/plugins/dev-browser-logs.d.ts.map +0 -1
- package/dist/plugins/dev-error-overlay.d.ts.map +0 -1
- package/dist/plugins/dev-error-page.d.ts.map +0 -1
- package/dist/plugins/dev-logs.d.ts.map +0 -1
- package/dist/plugins/dev-terminal-error.d.ts.map +0 -1
- package/dist/server/deny-page-resolver.d.ts +0 -52
- package/dist/server/deny-page-resolver.d.ts.map +0 -1
- package/dist/server/dev-fetch-instrumentation.d.ts +0 -22
- package/dist/server/dev-fetch-instrumentation.d.ts.map +0 -1
- package/dist/server/dev-holding-server.d.ts.map +0 -1
- package/dist/server/dev-logger.d.ts.map +0 -1
- package/dist/server/dev-span-processor.d.ts.map +0 -1
- package/dist/server/dev-warnings.d.ts.map +0 -1
- package/dist/server/manifest-status-resolver.d.ts +0 -58
- package/dist/server/manifest-status-resolver.d.ts.map +0 -1
- package/dist/server/page-deny-boundary.d.ts +0 -31
- package/dist/server/page-deny-boundary.d.ts.map +0 -1
- package/src/server/dev-fetch-instrumentation.ts +0 -96
- package/src/server/dev-span-processor.ts +0 -78
- package/src/server/manifest-status-resolver.ts +0 -215
- package/src/server/page-deny-boundary.tsx +0 -56
- /package/src/client/{use-params.ts → use-segment-params.ts} +0 -0
- /package/src/{plugins/dev-browser-logs.ts → dev-tools/browser-logs.ts} +0 -0
- /package/src/{server/dev-logger.ts → dev-tools/logger.ts} +0 -0
|
@@ -10,6 +10,7 @@
|
|
|
10
10
|
|
|
11
11
|
import type { RouteMatch } from './pipeline.js';
|
|
12
12
|
import type { MiddlewareFn } from './middleware-runner.js';
|
|
13
|
+
import type { SegmentNode, RouteTree } from '../routing/types.js';
|
|
13
14
|
import {
|
|
14
15
|
METADATA_ROUTE_CONVENTIONS,
|
|
15
16
|
isStaticMetadataExtension,
|
|
@@ -18,71 +19,40 @@ import {
|
|
|
18
19
|
} from './metadata-routes.js';
|
|
19
20
|
|
|
20
21
|
// ─── Manifest Types ───────────────────────────────────────────────────────
|
|
21
|
-
//
|
|
22
|
-
//
|
|
22
|
+
//
|
|
23
|
+
// TIM-848: the runtime route manifest re-uses the same `SegmentNode<TFile>`
|
|
24
|
+
// / `RouteTree<TFile>` interfaces from `routing/types.ts`. The only
|
|
25
|
+
// difference between build-time and runtime is the file reference payload
|
|
26
|
+
// — build-time has `{ filePath, extension }`, runtime has `{ filePath, load }`.
|
|
27
|
+
// Walkers parameterized over `TFile` work on either; there is no separate
|
|
28
|
+
// "manifest" tree shape.
|
|
23
29
|
|
|
24
30
|
/** A file reference in the manifest (lazy import + path). */
|
|
25
|
-
interface ManifestFile {
|
|
31
|
+
export interface ManifestFile {
|
|
26
32
|
load: () => Promise<unknown>;
|
|
27
33
|
filePath: string;
|
|
28
34
|
}
|
|
29
35
|
|
|
30
|
-
/**
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
| 'group'
|
|
39
|
-
| 'slot'
|
|
40
|
-
| 'intercepting';
|
|
41
|
-
urlPath: string;
|
|
42
|
-
paramName?: string;
|
|
43
|
-
/** For intercepting segments: the marker used, e.g. "(.)". */
|
|
44
|
-
interceptionMarker?: '(.)' | '(..)' | '(...)' | '(..)(..)';
|
|
45
|
-
/** For intercepting segments: the segment name after stripping the marker. */
|
|
46
|
-
interceptedSegmentName?: string;
|
|
47
|
-
|
|
48
|
-
page?: ManifestFile;
|
|
49
|
-
layout?: ManifestFile;
|
|
50
|
-
middleware?: ManifestFile;
|
|
51
|
-
access?: ManifestFile;
|
|
52
|
-
route?: ManifestFile;
|
|
53
|
-
/** params.ts — isomorphic convention file for segmentParams + searchParams definitions. */
|
|
54
|
-
params?: ManifestFile;
|
|
55
|
-
error?: ManifestFile;
|
|
56
|
-
default?: ManifestFile;
|
|
57
|
-
denied?: ManifestFile;
|
|
58
|
-
statusFiles?: Record<string, ManifestFile>;
|
|
59
|
-
jsonStatusFiles?: Record<string, ManifestFile>;
|
|
60
|
-
legacyStatusFiles?: Record<string, ManifestFile>;
|
|
61
|
-
/** Metadata route files (sitemap.ts, robots.ts, icon.tsx, etc.) keyed by base name */
|
|
62
|
-
metadataRoutes?: Record<string, ManifestFile>;
|
|
63
|
-
|
|
64
|
-
children: ManifestSegmentNode[];
|
|
65
|
-
slots: Record<string, ManifestSegmentNode>;
|
|
66
|
-
}
|
|
36
|
+
/**
|
|
37
|
+
* A segment node as it appears in the virtual:timber-route-manifest module.
|
|
38
|
+
*
|
|
39
|
+
* Type alias for `SegmentNode<ManifestFile>` — the same shape used by the
|
|
40
|
+
* scanner, only with lazy `load` functions instead of build-time extension
|
|
41
|
+
* metadata.
|
|
42
|
+
*/
|
|
43
|
+
export type ManifestSegmentNode = SegmentNode<ManifestFile>;
|
|
67
44
|
|
|
68
|
-
/**
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
45
|
+
/**
|
|
46
|
+
* The manifest shape from virtual:timber-route-manifest.
|
|
47
|
+
*
|
|
48
|
+
* Extends `RouteTree<ManifestFile>` with `viteRoot`, the absolute path
|
|
49
|
+
* to the Vite project root captured at build/load time. Used by dev-only
|
|
50
|
+
* features (e.g., dev error page frame classification) that need a
|
|
51
|
+
* correct project root even when CWD differs (e.g., monorepo custom root).
|
|
52
|
+
* See TIM-807 / TIM-808.
|
|
53
|
+
*/
|
|
54
|
+
export interface ManifestRoot extends RouteTree<ManifestFile> {
|
|
77
55
|
viteRoot: string;
|
|
78
|
-
proxy?: ManifestFile;
|
|
79
|
-
/**
|
|
80
|
-
* Global error page: app/global-error.{tsx,ts,jsx,js}
|
|
81
|
-
* Tier 2 — standalone full-page replacement (no layouts) when no
|
|
82
|
-
* segment-level error file is found. SSR-only render.
|
|
83
|
-
* See design/10-error-handling.md §"Tier 2"
|
|
84
|
-
*/
|
|
85
|
-
globalError?: ManifestFile;
|
|
86
56
|
}
|
|
87
57
|
|
|
88
58
|
// ─── Matcher ──────────────────────────────────────────────────────────────
|
|
@@ -132,9 +102,7 @@ function matchPathname(root: ManifestSegmentNode, pathname: string): RouteMatch
|
|
|
132
102
|
}
|
|
133
103
|
|
|
134
104
|
return {
|
|
135
|
-
|
|
136
|
-
// Cast is safe — the renderer receives what the manifest provides.
|
|
137
|
-
segments: segments as unknown as RouteMatch['segments'],
|
|
105
|
+
segments,
|
|
138
106
|
segmentParams: params,
|
|
139
107
|
middlewareChain,
|
|
140
108
|
};
|
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Middleware-on-actions runner — runs the matched route's `middleware.ts`
|
|
3
|
+
* chain for an action POST inside its own `runWithRequestContext` scope
|
|
4
|
+
* and returns a `MiddlewareOutcome` value the dispatcher can translate.
|
|
5
|
+
*
|
|
6
|
+
* Lifted out of `wrap-action-dispatch.ts` (TIM-853) so the dispatcher
|
|
7
|
+
* can be read top-to-bottom without scrolling past the chain runner. The
|
|
8
|
+
* function is intentionally a free function (not a closure over deps)
|
|
9
|
+
* so it can be unit-tested in isolation. It does not import virtual
|
|
10
|
+
* modules and does not call into the action handler — it owns exactly
|
|
11
|
+
* the "run middleware once" step and nothing else.
|
|
12
|
+
*
|
|
13
|
+
* Failure modes are encoded as outcome variants rather than thrown so the
|
|
14
|
+
* caller never has to wrap this in try/catch. The only thrown errors are
|
|
15
|
+
* truly unexpected (programmer bugs) and propagate naturally.
|
|
16
|
+
*
|
|
17
|
+
* See TIM-871 for the full design rationale (closing the
|
|
18
|
+
* CVE-2025-29927-class bug where actions silently bypass middleware).
|
|
19
|
+
*/
|
|
20
|
+
|
|
21
|
+
import { getCookiesForSsr, getSetCookieHeaders } from '../cookie-context.js';
|
|
22
|
+
import {
|
|
23
|
+
applyRequestHeaderOverlay,
|
|
24
|
+
runWithRequestContext,
|
|
25
|
+
setMutableCookieContext,
|
|
26
|
+
setSegmentParams,
|
|
27
|
+
} from '../request-context.js';
|
|
28
|
+
import { runMiddlewareChain } from '../middleware-runner.js';
|
|
29
|
+
import { DenySignal, RedirectSignal } from '../primitives.js';
|
|
30
|
+
import { ParamCoercionError } from '../route-element-builder.js';
|
|
31
|
+
import type { RouteMatch } from '../pipeline.js';
|
|
32
|
+
import type { MiddlewareContext } from '../types.js';
|
|
33
|
+
|
|
34
|
+
/** Coerce a matched route's segment params via its `params.ts` codecs. */
|
|
35
|
+
export type CoerceSegmentParamsFn = (match: RouteMatch) => Promise<void>;
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* Outcome of running middleware on an action request, surfaced from the
|
|
39
|
+
* inner `runWithRequestContext` scope so the outer dispatcher can convert
|
|
40
|
+
* it to a Response (short-circuit) or continue to the action handler.
|
|
41
|
+
*
|
|
42
|
+
* Each variant carries the post-middleware Set-Cookie snapshot so the
|
|
43
|
+
* outer scope can apply cookies to whichever Response it ultimately
|
|
44
|
+
* returns. The middleware ALS scope ends before the action ALS scope
|
|
45
|
+
* begins, so cookie state must be threaded explicitly across the boundary
|
|
46
|
+
* via `seedRequestCookies` (cookie reads) and `setCookieHeaders` (cookie
|
|
47
|
+
* writes).
|
|
48
|
+
*/
|
|
49
|
+
export type MiddlewareOutcome =
|
|
50
|
+
| {
|
|
51
|
+
kind: 'continue';
|
|
52
|
+
overlay: Headers;
|
|
53
|
+
cookies: Map<string, string>;
|
|
54
|
+
setCookieHeaders: string[];
|
|
55
|
+
}
|
|
56
|
+
| {
|
|
57
|
+
kind: 'short-circuit';
|
|
58
|
+
response: Response;
|
|
59
|
+
setCookieHeaders: string[];
|
|
60
|
+
}
|
|
61
|
+
| {
|
|
62
|
+
kind: 'redirect';
|
|
63
|
+
signal: RedirectSignal;
|
|
64
|
+
setCookieHeaders: string[];
|
|
65
|
+
}
|
|
66
|
+
| {
|
|
67
|
+
kind: 'deny';
|
|
68
|
+
signal: DenySignal;
|
|
69
|
+
match: RouteMatch;
|
|
70
|
+
setCookieHeaders: string[];
|
|
71
|
+
}
|
|
72
|
+
| {
|
|
73
|
+
kind: 'param-coercion-error';
|
|
74
|
+
}
|
|
75
|
+
| {
|
|
76
|
+
kind: 'error';
|
|
77
|
+
error: unknown;
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
/**
|
|
81
|
+
* Run the matched route's middleware chain inside a fresh request-context
|
|
82
|
+
* scope, captured as a `MiddlewareOutcome` value the outer dispatcher can
|
|
83
|
+
* translate to a Response or use as the seed for the action handler.
|
|
84
|
+
*/
|
|
85
|
+
export async function runMiddlewareForAction(
|
|
86
|
+
req: Request,
|
|
87
|
+
match: RouteMatch,
|
|
88
|
+
coerceSegmentParams: CoerceSegmentParamsFn
|
|
89
|
+
): Promise<MiddlewareOutcome> {
|
|
90
|
+
return runWithRequestContext(req, async (): Promise<MiddlewareOutcome> => {
|
|
91
|
+
// ─── Coerce segment params (mirrors page pipeline) ──────────────
|
|
92
|
+
try {
|
|
93
|
+
await coerceSegmentParams(match);
|
|
94
|
+
} catch (err) {
|
|
95
|
+
if (err instanceof ParamCoercionError) {
|
|
96
|
+
return { kind: 'param-coercion-error' };
|
|
97
|
+
}
|
|
98
|
+
return { kind: 'error', error: err };
|
|
99
|
+
}
|
|
100
|
+
setSegmentParams(match.segmentParams);
|
|
101
|
+
|
|
102
|
+
// ─── Build the middleware context ───────────────────────────────
|
|
103
|
+
const responseHeaders = new Headers();
|
|
104
|
+
const requestHeaderOverlay = new Headers();
|
|
105
|
+
const ctx: MiddlewareContext = {
|
|
106
|
+
req,
|
|
107
|
+
requestHeaders: requestHeaderOverlay,
|
|
108
|
+
headers: responseHeaders,
|
|
109
|
+
segmentParams: match.segmentParams,
|
|
110
|
+
// 103 Early Hints are a page-render concern — server actions are
|
|
111
|
+
// RPC and never produce HTML, so there is nothing to hint about.
|
|
112
|
+
// Provide a no-op so user middleware can call `ctx.earlyHints()`
|
|
113
|
+
// unconditionally without branching on request kind.
|
|
114
|
+
earlyHints: () => {},
|
|
115
|
+
};
|
|
116
|
+
|
|
117
|
+
// ─── Run the chain ──────────────────────────────────────────────
|
|
118
|
+
setMutableCookieContext(true);
|
|
119
|
+
try {
|
|
120
|
+
let middlewareResponse: Response | undefined;
|
|
121
|
+
try {
|
|
122
|
+
middlewareResponse = await runMiddlewareChain(match.middlewareChain, ctx);
|
|
123
|
+
} catch (err) {
|
|
124
|
+
if (err instanceof RedirectSignal) {
|
|
125
|
+
return {
|
|
126
|
+
kind: 'redirect',
|
|
127
|
+
signal: err,
|
|
128
|
+
setCookieHeaders: getSetCookieHeaders(),
|
|
129
|
+
};
|
|
130
|
+
}
|
|
131
|
+
if (err instanceof DenySignal) {
|
|
132
|
+
return {
|
|
133
|
+
kind: 'deny',
|
|
134
|
+
signal: err,
|
|
135
|
+
match,
|
|
136
|
+
setCookieHeaders: getSetCookieHeaders(),
|
|
137
|
+
};
|
|
138
|
+
}
|
|
139
|
+
return { kind: 'error', error: err };
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
if (middlewareResponse) {
|
|
143
|
+
return {
|
|
144
|
+
kind: 'short-circuit',
|
|
145
|
+
response: middlewareResponse,
|
|
146
|
+
setCookieHeaders: getSetCookieHeaders(),
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
// Middleware passed — apply the request-header overlay to the
|
|
151
|
+
// current scope so any code that might still read it within
|
|
152
|
+
// this scope sees the merged view. The overlay is also captured
|
|
153
|
+
// in the outcome so the caller can re-apply it inside the
|
|
154
|
+
// action's request-context scope (which is a separate ALS run).
|
|
155
|
+
applyRequestHeaderOverlay(requestHeaderOverlay);
|
|
156
|
+
|
|
157
|
+
return {
|
|
158
|
+
kind: 'continue',
|
|
159
|
+
overlay: requestHeaderOverlay,
|
|
160
|
+
cookies: getCookiesForSsr(),
|
|
161
|
+
setCookieHeaders: getSetCookieHeaders(),
|
|
162
|
+
};
|
|
163
|
+
} finally {
|
|
164
|
+
setMutableCookieContext(false);
|
|
165
|
+
}
|
|
166
|
+
});
|
|
167
|
+
}
|
|
@@ -89,9 +89,9 @@ async function renderApiDeny(
|
|
|
89
89
|
segments: ManifestSegmentNode[],
|
|
90
90
|
responseHeaders: Headers
|
|
91
91
|
): Promise<Response> {
|
|
92
|
-
const {
|
|
92
|
+
const { resolveStatusFile } = await import('../status-code-resolver.js');
|
|
93
93
|
|
|
94
|
-
const resolution =
|
|
94
|
+
const resolution = resolveStatusFile(deny.status, segments, 'json');
|
|
95
95
|
if (resolution) {
|
|
96
96
|
const mod = await loadModule(resolution.file);
|
|
97
97
|
const jsonContent = mod.default ?? mod;
|
|
@@ -25,7 +25,7 @@ import { renderDenyPage } from '../deny-renderer.js';
|
|
|
25
25
|
import type { LayoutEntry } from '../deny-renderer.js';
|
|
26
26
|
import type { NavContext } from '../ssr-entry.js';
|
|
27
27
|
import { createDebugChannelSink } from './helpers.js';
|
|
28
|
-
import { getCookiesForSsr } from '../
|
|
28
|
+
import { getCookiesForSsr } from '../cookie-context.js';
|
|
29
29
|
import { callSsr } from './ssr-bridge.js';
|
|
30
30
|
import { teeWithErrorPropagation } from '../stream-utils.js';
|
|
31
31
|
import { isDevMode } from '../debug.js';
|
|
@@ -377,7 +377,7 @@ export async function renderNoMatchPage(
|
|
|
377
377
|
}
|
|
378
378
|
|
|
379
379
|
const deny = new DenySignal(404);
|
|
380
|
-
const match: RouteMatch = { segments
|
|
380
|
+
const match: RouteMatch = { segments, segmentParams: {}, middlewareChain: [] };
|
|
381
381
|
|
|
382
382
|
return renderDenyPage(
|
|
383
383
|
deny,
|
|
@@ -250,13 +250,8 @@ export function isAbortError(error: unknown): boolean {
|
|
|
250
250
|
return false;
|
|
251
251
|
}
|
|
252
252
|
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
.replace(/&/g, '&')
|
|
256
|
-
.replace(/</g, '<')
|
|
257
|
-
.replace(/>/g, '>')
|
|
258
|
-
.replace(/"/g, '"');
|
|
259
|
-
}
|
|
253
|
+
// escapeHtml is now imported from server/utils/escape-html.ts
|
|
254
|
+
export { escapeHtml } from '../utils/escape-html.js';
|
|
260
255
|
|
|
261
256
|
/**
|
|
262
257
|
* Parse a Cookie header string into a name→value Map.
|