@rangojs/router 0.0.0-experimental.9 → 0.0.0-experimental.91
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/AGENTS.md +9 -0
- package/README.md +972 -4
- package/dist/__internal.d.ts +83 -0
- package/dist/__internal.d.ts.map +1 -0
- package/dist/__internal.js +19 -0
- package/dist/__internal.js.map +1 -0
- package/dist/__mocks__/version.d.ts +7 -0
- package/dist/__mocks__/version.d.ts.map +1 -0
- package/dist/__mocks__/version.js +7 -0
- package/dist/__mocks__/version.js.map +1 -0
- package/dist/__tests__/client-href.test.d.ts +2 -0
- package/dist/__tests__/client-href.test.d.ts.map +1 -0
- package/dist/__tests__/client-href.test.js +74 -0
- package/dist/__tests__/client-href.test.js.map +1 -0
- package/dist/__tests__/component-utils.test.d.ts +2 -0
- package/dist/__tests__/component-utils.test.d.ts.map +1 -0
- package/dist/__tests__/component-utils.test.js +51 -0
- package/dist/__tests__/component-utils.test.js.map +1 -0
- package/dist/__tests__/event-controller.test.d.ts +2 -0
- package/dist/__tests__/event-controller.test.d.ts.map +1 -0
- package/dist/__tests__/event-controller.test.js +538 -0
- package/dist/__tests__/event-controller.test.js.map +1 -0
- package/dist/__tests__/helpers/route-tree.d.ts +118 -0
- package/dist/__tests__/helpers/route-tree.d.ts.map +1 -0
- package/dist/__tests__/helpers/route-tree.js +374 -0
- package/dist/__tests__/helpers/route-tree.js.map +1 -0
- package/dist/__tests__/match-result.test.d.ts +2 -0
- package/dist/__tests__/match-result.test.d.ts.map +1 -0
- package/dist/__tests__/match-result.test.js +154 -0
- package/dist/__tests__/match-result.test.js.map +1 -0
- package/dist/__tests__/navigation-store.test.d.ts +2 -0
- package/dist/__tests__/navigation-store.test.d.ts.map +1 -0
- package/dist/__tests__/navigation-store.test.js +440 -0
- package/dist/__tests__/navigation-store.test.js.map +1 -0
- package/dist/__tests__/partial-update.test.d.ts +2 -0
- package/dist/__tests__/partial-update.test.d.ts.map +1 -0
- package/dist/__tests__/partial-update.test.js +1009 -0
- package/dist/__tests__/partial-update.test.js.map +1 -0
- package/dist/__tests__/reverse-types.test.d.ts +8 -0
- package/dist/__tests__/reverse-types.test.d.ts.map +1 -0
- package/dist/__tests__/reverse-types.test.js +656 -0
- package/dist/__tests__/reverse-types.test.js.map +1 -0
- package/dist/__tests__/route-definition.test.d.ts +2 -0
- package/dist/__tests__/route-definition.test.d.ts.map +1 -0
- package/dist/__tests__/route-definition.test.js +55 -0
- package/dist/__tests__/route-definition.test.js.map +1 -0
- package/dist/__tests__/router-helpers.test.d.ts +2 -0
- package/dist/__tests__/router-helpers.test.d.ts.map +1 -0
- package/dist/__tests__/router-helpers.test.js +377 -0
- package/dist/__tests__/router-helpers.test.js.map +1 -0
- package/dist/__tests__/router-integration-2.test.d.ts +2 -0
- package/dist/__tests__/router-integration-2.test.d.ts.map +1 -0
- package/dist/__tests__/router-integration-2.test.js +426 -0
- package/dist/__tests__/router-integration-2.test.js.map +1 -0
- package/dist/__tests__/router-integration.test.d.ts +2 -0
- package/dist/__tests__/router-integration.test.d.ts.map +1 -0
- package/dist/__tests__/router-integration.test.js +1051 -0
- package/dist/__tests__/router-integration.test.js.map +1 -0
- package/dist/__tests__/search-params.test.d.ts +5 -0
- package/dist/__tests__/search-params.test.d.ts.map +1 -0
- package/dist/__tests__/search-params.test.js +306 -0
- package/dist/__tests__/search-params.test.js.map +1 -0
- package/dist/__tests__/segment-system.test.d.ts +2 -0
- package/dist/__tests__/segment-system.test.d.ts.map +1 -0
- package/dist/__tests__/segment-system.test.js +627 -0
- package/dist/__tests__/segment-system.test.js.map +1 -0
- package/dist/__tests__/static-handler-types.test.d.ts +8 -0
- package/dist/__tests__/static-handler-types.test.d.ts.map +1 -0
- package/dist/__tests__/static-handler-types.test.js +63 -0
- package/dist/__tests__/static-handler-types.test.js.map +1 -0
- package/dist/__tests__/urls.test.d.ts +2 -0
- package/dist/__tests__/urls.test.d.ts.map +1 -0
- package/dist/__tests__/urls.test.js +421 -0
- package/dist/__tests__/urls.test.js.map +1 -0
- package/dist/__tests__/use-mount.test.d.ts +2 -0
- package/dist/__tests__/use-mount.test.d.ts.map +1 -0
- package/dist/__tests__/use-mount.test.js +35 -0
- package/dist/__tests__/use-mount.test.js.map +1 -0
- package/dist/bin/rango.d.ts +2 -0
- package/dist/bin/rango.d.ts.map +1 -0
- package/dist/bin/rango.js +1619 -155
- package/dist/bin/rango.js.map +1 -0
- package/dist/browser/event-controller.d.ts +191 -0
- package/dist/browser/event-controller.d.ts.map +1 -0
- package/dist/browser/event-controller.js +559 -0
- package/dist/browser/event-controller.js.map +1 -0
- package/dist/browser/index.d.ts +2 -0
- package/dist/browser/index.d.ts.map +1 -0
- package/dist/browser/index.js +14 -0
- package/dist/browser/index.js.map +1 -0
- package/dist/browser/link-interceptor.d.ts +38 -0
- package/dist/browser/link-interceptor.d.ts.map +1 -0
- package/dist/browser/link-interceptor.js +99 -0
- package/dist/browser/link-interceptor.js.map +1 -0
- package/dist/browser/logging.d.ts +10 -0
- package/dist/browser/logging.d.ts.map +1 -0
- package/dist/browser/logging.js +29 -0
- package/dist/browser/logging.js.map +1 -0
- package/dist/browser/lru-cache.d.ts +17 -0
- package/dist/browser/lru-cache.d.ts.map +1 -0
- package/dist/browser/lru-cache.js +50 -0
- package/dist/browser/lru-cache.js.map +1 -0
- package/dist/browser/merge-segment-loaders.d.ts +39 -0
- package/dist/browser/merge-segment-loaders.d.ts.map +1 -0
- package/dist/browser/merge-segment-loaders.js +102 -0
- package/dist/browser/merge-segment-loaders.js.map +1 -0
- package/dist/browser/navigation-bridge.d.ts +102 -0
- package/dist/browser/navigation-bridge.d.ts.map +1 -0
- package/dist/browser/navigation-bridge.js +708 -0
- package/dist/browser/navigation-bridge.js.map +1 -0
- package/dist/browser/navigation-client.d.ts +25 -0
- package/dist/browser/navigation-client.d.ts.map +1 -0
- package/dist/browser/navigation-client.js +157 -0
- package/dist/browser/navigation-client.js.map +1 -0
- package/dist/browser/navigation-store.d.ts +101 -0
- package/dist/browser/navigation-store.d.ts.map +1 -0
- package/dist/browser/navigation-store.js +625 -0
- package/dist/browser/navigation-store.js.map +1 -0
- package/dist/browser/partial-update.d.ts +75 -0
- package/dist/browser/partial-update.d.ts.map +1 -0
- package/dist/browser/partial-update.js +426 -0
- package/dist/browser/partial-update.js.map +1 -0
- package/dist/browser/react/Link.d.ts +86 -0
- package/dist/browser/react/Link.d.ts.map +1 -0
- package/dist/browser/react/Link.js +128 -0
- package/dist/browser/react/Link.js.map +1 -0
- package/dist/browser/react/NavigationProvider.d.ts +63 -0
- package/dist/browser/react/NavigationProvider.d.ts.map +1 -0
- package/dist/browser/react/NavigationProvider.js +216 -0
- package/dist/browser/react/NavigationProvider.js.map +1 -0
- package/dist/browser/react/ScrollRestoration.d.ts +75 -0
- package/dist/browser/react/ScrollRestoration.d.ts.map +1 -0
- package/dist/browser/react/ScrollRestoration.js +57 -0
- package/dist/browser/react/ScrollRestoration.js.map +1 -0
- package/dist/browser/react/context.d.ts +46 -0
- package/dist/browser/react/context.d.ts.map +1 -0
- package/dist/browser/react/context.js +10 -0
- package/dist/browser/react/context.js.map +1 -0
- package/dist/browser/react/index.d.ts +11 -0
- package/dist/browser/react/index.d.ts.map +1 -0
- package/dist/browser/react/index.js +22 -0
- package/dist/browser/react/index.js.map +1 -0
- package/dist/browser/react/location-state-shared.d.ts +63 -0
- package/dist/browser/react/location-state-shared.d.ts.map +1 -0
- package/dist/browser/react/location-state-shared.js +81 -0
- package/dist/browser/react/location-state-shared.js.map +1 -0
- package/dist/browser/react/location-state.d.ts +23 -0
- package/dist/browser/react/location-state.d.ts.map +1 -0
- package/dist/browser/react/location-state.js +29 -0
- package/dist/browser/react/location-state.js.map +1 -0
- package/dist/browser/react/mount-context.d.ts +24 -0
- package/dist/browser/react/mount-context.d.ts.map +1 -0
- package/dist/browser/react/mount-context.js +24 -0
- package/dist/browser/react/mount-context.js.map +1 -0
- package/dist/browser/react/use-action.d.ts +64 -0
- package/dist/browser/react/use-action.d.ts.map +1 -0
- package/dist/browser/react/use-action.js +134 -0
- package/dist/browser/react/use-action.js.map +1 -0
- package/dist/browser/react/use-client-cache.d.ts +41 -0
- package/dist/browser/react/use-client-cache.d.ts.map +1 -0
- package/dist/browser/react/use-client-cache.js +39 -0
- package/dist/browser/react/use-client-cache.js.map +1 -0
- package/dist/browser/react/use-handle.d.ts +31 -0
- package/dist/browser/react/use-handle.d.ts.map +1 -0
- package/dist/browser/react/use-handle.js +144 -0
- package/dist/browser/react/use-handle.js.map +1 -0
- package/dist/browser/react/use-href.d.ts +33 -0
- package/dist/browser/react/use-href.d.ts.map +1 -0
- package/dist/browser/react/use-href.js +39 -0
- package/dist/browser/react/use-href.js.map +1 -0
- package/dist/browser/react/use-link-status.d.ts +37 -0
- package/dist/browser/react/use-link-status.d.ts.map +1 -0
- package/dist/browser/react/use-link-status.js +99 -0
- package/dist/browser/react/use-link-status.js.map +1 -0
- package/dist/browser/react/use-mount.d.ts +25 -0
- package/dist/browser/react/use-mount.d.ts.map +1 -0
- package/dist/browser/react/use-mount.js +30 -0
- package/dist/browser/react/use-mount.js.map +1 -0
- package/dist/browser/react/use-navigation.d.ts +27 -0
- package/dist/browser/react/use-navigation.d.ts.map +1 -0
- package/dist/browser/react/use-navigation.js +87 -0
- package/dist/browser/react/use-navigation.js.map +1 -0
- package/dist/browser/react/use-segments.d.ts +38 -0
- package/dist/browser/react/use-segments.d.ts.map +1 -0
- package/dist/browser/react/use-segments.js +130 -0
- package/dist/browser/react/use-segments.js.map +1 -0
- package/dist/browser/request-controller.d.ts +26 -0
- package/dist/browser/request-controller.d.ts.map +1 -0
- package/dist/browser/request-controller.js +147 -0
- package/dist/browser/request-controller.js.map +1 -0
- package/dist/browser/rsc-router.d.ts +129 -0
- package/dist/browser/rsc-router.d.ts.map +1 -0
- package/dist/browser/rsc-router.js +195 -0
- package/dist/browser/rsc-router.js.map +1 -0
- package/dist/browser/scroll-restoration.d.ts +93 -0
- package/dist/browser/scroll-restoration.d.ts.map +1 -0
- package/dist/browser/scroll-restoration.js +321 -0
- package/dist/browser/scroll-restoration.js.map +1 -0
- package/dist/browser/segment-structure-assert.d.ts +17 -0
- package/dist/browser/segment-structure-assert.d.ts.map +1 -0
- package/dist/browser/segment-structure-assert.js +59 -0
- package/dist/browser/segment-structure-assert.js.map +1 -0
- package/dist/browser/server-action-bridge.d.ts +26 -0
- package/dist/browser/server-action-bridge.d.ts.map +1 -0
- package/dist/browser/server-action-bridge.js +668 -0
- package/dist/browser/server-action-bridge.js.map +1 -0
- package/dist/browser/shallow.d.ts +12 -0
- package/dist/browser/shallow.d.ts.map +1 -0
- package/dist/browser/shallow.js +34 -0
- package/dist/browser/shallow.js.map +1 -0
- package/dist/browser/types.d.ts +369 -0
- package/dist/browser/types.d.ts.map +1 -0
- package/dist/browser/types.js +2 -0
- package/dist/browser/types.js.map +1 -0
- package/dist/build/__tests__/generate-cli.test.d.ts +2 -0
- package/dist/build/__tests__/generate-cli.test.d.ts.map +1 -0
- package/dist/build/__tests__/generate-cli.test.js +237 -0
- package/dist/build/__tests__/generate-cli.test.js.map +1 -0
- package/dist/build/__tests__/generate-manifest.test.d.ts +2 -0
- package/dist/build/__tests__/generate-manifest.test.d.ts.map +1 -0
- package/dist/build/__tests__/generate-manifest.test.js +119 -0
- package/dist/build/__tests__/generate-manifest.test.js.map +1 -0
- package/dist/build/__tests__/generate-route-types.test.d.ts +2 -0
- package/dist/build/__tests__/generate-route-types.test.d.ts.map +1 -0
- package/dist/build/__tests__/generate-route-types.test.js +620 -0
- package/dist/build/__tests__/generate-route-types.test.js.map +1 -0
- package/dist/build/__tests__/per-router-manifest.test.d.ts +2 -0
- package/dist/build/__tests__/per-router-manifest.test.d.ts.map +1 -0
- package/dist/build/__tests__/per-router-manifest.test.js +308 -0
- package/dist/build/__tests__/per-router-manifest.test.js.map +1 -0
- package/dist/build/generate-manifest.d.ts +81 -0
- package/dist/build/generate-manifest.d.ts.map +1 -0
- package/dist/build/generate-manifest.js +276 -0
- package/dist/build/generate-manifest.js.map +1 -0
- package/dist/build/generate-route-types.d.ts +115 -0
- package/dist/build/generate-route-types.d.ts.map +1 -0
- package/dist/build/generate-route-types.js +740 -0
- package/dist/build/generate-route-types.js.map +1 -0
- package/dist/build/index.d.ts +21 -0
- package/dist/build/index.d.ts.map +1 -0
- package/dist/build/index.js +21 -0
- package/dist/build/index.js.map +1 -0
- package/dist/build/route-trie.d.ts +71 -0
- package/dist/build/route-trie.d.ts.map +1 -0
- package/dist/build/route-trie.js +175 -0
- package/dist/build/route-trie.js.map +1 -0
- package/dist/cache/__tests__/cache-scope.test.d.ts +2 -0
- package/dist/cache/__tests__/cache-scope.test.d.ts.map +1 -0
- package/dist/cache/__tests__/cache-scope.test.js +208 -0
- package/dist/cache/__tests__/cache-scope.test.js.map +1 -0
- package/dist/cache/__tests__/document-cache.test.d.ts +2 -0
- package/dist/cache/__tests__/document-cache.test.d.ts.map +1 -0
- package/dist/cache/__tests__/document-cache.test.js +345 -0
- package/dist/cache/__tests__/document-cache.test.js.map +1 -0
- package/dist/cache/__tests__/memory-segment-store.test.d.ts +2 -0
- package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +1 -0
- package/dist/cache/__tests__/memory-segment-store.test.js +425 -0
- package/dist/cache/__tests__/memory-segment-store.test.js.map +1 -0
- package/dist/cache/__tests__/memory-store.test.d.ts +2 -0
- package/dist/cache/__tests__/memory-store.test.d.ts.map +1 -0
- package/dist/cache/__tests__/memory-store.test.js +367 -0
- package/dist/cache/__tests__/memory-store.test.js.map +1 -0
- package/dist/cache/cache-scope.d.ts +102 -0
- package/dist/cache/cache-scope.d.ts.map +1 -0
- package/dist/cache/cache-scope.js +440 -0
- package/dist/cache/cache-scope.js.map +1 -0
- package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +2 -0
- package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +1 -0
- package/dist/cache/cf/__tests__/cf-cache-store.test.js +330 -0
- package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +1 -0
- package/dist/cache/cf/cf-cache-store.d.ts +165 -0
- package/dist/cache/cf/cf-cache-store.d.ts.map +1 -0
- package/dist/cache/cf/cf-cache-store.js +242 -0
- package/dist/cache/cf/cf-cache-store.js.map +1 -0
- package/dist/cache/cf/index.d.ts +14 -0
- package/dist/cache/cf/index.d.ts.map +1 -0
- package/dist/cache/cf/index.js +17 -0
- package/dist/cache/cf/index.js.map +1 -0
- package/dist/cache/document-cache.d.ts +64 -0
- package/dist/cache/document-cache.d.ts.map +1 -0
- package/dist/cache/document-cache.js +228 -0
- package/dist/cache/document-cache.js.map +1 -0
- package/dist/cache/index.d.ts +19 -0
- package/dist/cache/index.d.ts.map +1 -0
- package/dist/cache/index.js +21 -0
- package/dist/cache/index.js.map +1 -0
- package/dist/cache/memory-segment-store.d.ts +110 -0
- package/dist/cache/memory-segment-store.d.ts.map +1 -0
- package/dist/cache/memory-segment-store.js +117 -0
- package/dist/cache/memory-segment-store.js.map +1 -0
- package/dist/cache/memory-store.d.ts +41 -0
- package/dist/cache/memory-store.d.ts.map +1 -0
- package/dist/cache/memory-store.js +191 -0
- package/dist/cache/memory-store.js.map +1 -0
- package/dist/cache/types.d.ts +317 -0
- package/dist/cache/types.d.ts.map +1 -0
- package/dist/cache/types.js +12 -0
- package/dist/cache/types.js.map +1 -0
- package/dist/client.d.ts +248 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +367 -0
- package/dist/client.js.map +1 -0
- package/dist/client.rsc.d.ts +26 -0
- package/dist/client.rsc.d.ts.map +1 -0
- package/dist/client.rsc.js +46 -0
- package/dist/client.rsc.js.map +1 -0
- package/dist/component-utils.d.ts +36 -0
- package/dist/component-utils.d.ts.map +1 -0
- package/dist/component-utils.js +61 -0
- package/dist/component-utils.js.map +1 -0
- package/dist/components/DefaultDocument.d.ts +13 -0
- package/dist/components/DefaultDocument.d.ts.map +1 -0
- package/dist/components/DefaultDocument.js +15 -0
- package/dist/components/DefaultDocument.js.map +1 -0
- package/dist/debug.d.ts +58 -0
- package/dist/debug.d.ts.map +1 -0
- package/dist/debug.js +157 -0
- package/dist/debug.js.map +1 -0
- package/dist/default-error-boundary.d.ts +11 -0
- package/dist/default-error-boundary.d.ts.map +1 -0
- package/dist/default-error-boundary.js +45 -0
- package/dist/default-error-boundary.js.map +1 -0
- package/dist/deps/browser.d.ts +2 -0
- package/dist/deps/browser.d.ts.map +1 -0
- package/dist/deps/browser.js +3 -0
- package/dist/deps/browser.js.map +1 -0
- package/dist/deps/html-stream-client.d.ts +2 -0
- package/dist/deps/html-stream-client.d.ts.map +1 -0
- package/dist/deps/html-stream-client.js +3 -0
- package/dist/deps/html-stream-client.js.map +1 -0
- package/dist/deps/html-stream-server.d.ts +2 -0
- package/dist/deps/html-stream-server.d.ts.map +1 -0
- package/dist/deps/html-stream-server.js +3 -0
- package/dist/deps/html-stream-server.js.map +1 -0
- package/dist/deps/rsc.d.ts +2 -0
- package/dist/deps/rsc.d.ts.map +1 -0
- package/dist/deps/rsc.js +4 -0
- package/dist/deps/rsc.js.map +1 -0
- package/dist/deps/ssr.d.ts +2 -0
- package/dist/deps/ssr.d.ts.map +1 -0
- package/dist/deps/ssr.js +3 -0
- package/dist/deps/ssr.js.map +1 -0
- package/dist/errors.d.ts +174 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/errors.js +241 -0
- package/dist/errors.js.map +1 -0
- package/dist/handle.d.ts +78 -0
- package/dist/handle.d.ts.map +1 -0
- package/dist/handle.js +82 -0
- package/dist/handle.js.map +1 -0
- package/dist/handles/MetaTags.d.ts +14 -0
- package/dist/handles/MetaTags.d.ts.map +1 -0
- package/dist/handles/MetaTags.js +136 -0
- package/dist/handles/MetaTags.js.map +1 -0
- package/dist/handles/index.d.ts +6 -0
- package/dist/handles/index.d.ts.map +1 -0
- package/dist/handles/index.js +6 -0
- package/dist/handles/index.js.map +1 -0
- package/dist/handles/meta.d.ts +39 -0
- package/dist/handles/meta.d.ts.map +1 -0
- package/dist/handles/meta.js +202 -0
- package/dist/handles/meta.js.map +1 -0
- package/dist/host/__tests__/errors.test.d.ts +2 -0
- package/dist/host/__tests__/errors.test.d.ts.map +1 -0
- package/dist/host/__tests__/errors.test.js +76 -0
- package/dist/host/__tests__/errors.test.js.map +1 -0
- package/dist/host/__tests__/pattern-comprehensive.test.d.ts +2 -0
- package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +1 -0
- package/dist/host/__tests__/pattern-comprehensive.test.js +732 -0
- package/dist/host/__tests__/pattern-comprehensive.test.js.map +1 -0
- package/dist/host/__tests__/pattern-matcher.test.d.ts +2 -0
- package/dist/host/__tests__/pattern-matcher.test.d.ts.map +1 -0
- package/dist/host/__tests__/pattern-matcher.test.js +251 -0
- package/dist/host/__tests__/pattern-matcher.test.js.map +1 -0
- package/dist/host/__tests__/router.test.d.ts +2 -0
- package/dist/host/__tests__/router.test.d.ts.map +1 -0
- package/dist/host/__tests__/router.test.js +241 -0
- package/dist/host/__tests__/router.test.js.map +1 -0
- package/dist/host/__tests__/testing.test.d.ts +2 -0
- package/dist/host/__tests__/testing.test.d.ts.map +1 -0
- package/dist/host/__tests__/testing.test.js +64 -0
- package/dist/host/__tests__/testing.test.js.map +1 -0
- package/dist/host/__tests__/utils.test.d.ts +2 -0
- package/dist/host/__tests__/utils.test.d.ts.map +1 -0
- package/dist/host/__tests__/utils.test.js +29 -0
- package/dist/host/__tests__/utils.test.js.map +1 -0
- package/dist/host/cookie-handler.d.ts +34 -0
- package/dist/host/cookie-handler.d.ts.map +1 -0
- package/dist/host/cookie-handler.js +124 -0
- package/dist/host/cookie-handler.js.map +1 -0
- package/dist/host/errors.d.ts +56 -0
- package/dist/host/errors.d.ts.map +1 -0
- package/dist/host/errors.js +79 -0
- package/dist/host/errors.js.map +1 -0
- package/dist/host/index.d.ts +29 -0
- package/dist/host/index.d.ts.map +1 -0
- package/dist/host/index.js +32 -0
- package/dist/host/index.js.map +1 -0
- package/dist/host/pattern-matcher.d.ts +36 -0
- package/dist/host/pattern-matcher.d.ts.map +1 -0
- package/dist/host/pattern-matcher.js +172 -0
- package/dist/host/pattern-matcher.js.map +1 -0
- package/dist/host/router.d.ts +26 -0
- package/dist/host/router.d.ts.map +1 -0
- package/dist/host/router.js +218 -0
- package/dist/host/router.js.map +1 -0
- package/dist/host/testing.d.ts +36 -0
- package/dist/host/testing.d.ts.map +1 -0
- package/dist/host/testing.js +55 -0
- package/dist/host/testing.js.map +1 -0
- package/dist/host/types.d.ts +115 -0
- package/dist/host/types.d.ts.map +1 -0
- package/dist/host/types.js +7 -0
- package/dist/host/types.js.map +1 -0
- package/dist/host/utils.d.ts +21 -0
- package/dist/host/utils.d.ts.map +1 -0
- package/dist/host/utils.js +23 -0
- package/dist/host/utils.js.map +1 -0
- package/dist/href-client.d.ts +131 -0
- package/dist/href-client.d.ts.map +1 -0
- package/dist/href-client.js +64 -0
- package/dist/href-client.js.map +1 -0
- package/{src/href-context.ts → dist/href-context.d.ts} +7 -11
- package/dist/href-context.d.ts.map +1 -0
- package/dist/href-context.js +21 -0
- package/dist/href-context.js.map +1 -0
- package/dist/index.d.ts +73 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +91 -0
- package/dist/index.js.map +1 -0
- package/dist/index.rsc.d.ts +32 -0
- package/dist/index.rsc.d.ts.map +1 -0
- package/dist/index.rsc.js +40 -0
- package/dist/index.rsc.js.map +1 -0
- package/dist/internal-debug.d.ts +2 -0
- package/dist/internal-debug.d.ts.map +1 -0
- package/dist/internal-debug.js +5 -0
- package/dist/internal-debug.js.map +1 -0
- package/dist/loader.d.ts +14 -0
- package/dist/loader.d.ts.map +1 -0
- package/dist/loader.js +20 -0
- package/dist/loader.js.map +1 -0
- package/dist/loader.rsc.d.ts +19 -0
- package/dist/loader.rsc.d.ts.map +1 -0
- package/dist/loader.rsc.js +99 -0
- package/dist/loader.rsc.js.map +1 -0
- package/dist/network-error-thrower.d.ts +17 -0
- package/dist/network-error-thrower.d.ts.map +1 -0
- package/dist/network-error-thrower.js +14 -0
- package/dist/network-error-thrower.js.map +1 -0
- package/dist/outlet-context.d.ts +13 -0
- package/dist/outlet-context.d.ts.map +1 -0
- package/dist/outlet-context.js +3 -0
- package/dist/outlet-context.js.map +1 -0
- package/dist/prerender/__tests__/param-hash.test.d.ts +2 -0
- package/dist/prerender/__tests__/param-hash.test.d.ts.map +1 -0
- package/dist/prerender/__tests__/param-hash.test.js +148 -0
- package/dist/prerender/__tests__/param-hash.test.js.map +1 -0
- package/dist/prerender/param-hash.d.ts +16 -0
- package/dist/prerender/param-hash.d.ts.map +1 -0
- package/dist/prerender/param-hash.js +36 -0
- package/dist/prerender/param-hash.js.map +1 -0
- package/dist/prerender/store.d.ts +38 -0
- package/dist/prerender/store.d.ts.map +1 -0
- package/dist/prerender/store.js +61 -0
- package/dist/prerender/store.js.map +1 -0
- package/dist/prerender.d.ts +66 -0
- package/dist/prerender.d.ts.map +1 -0
- package/dist/prerender.js +57 -0
- package/dist/prerender.js.map +1 -0
- package/dist/reverse.d.ts +196 -0
- package/dist/reverse.d.ts.map +1 -0
- package/dist/reverse.js +78 -0
- package/dist/reverse.js.map +1 -0
- package/dist/root-error-boundary.d.ts +33 -0
- package/dist/root-error-boundary.d.ts.map +1 -0
- package/dist/root-error-boundary.js +165 -0
- package/dist/root-error-boundary.js.map +1 -0
- package/dist/route-content-wrapper.d.ts +46 -0
- package/dist/route-content-wrapper.d.ts.map +1 -0
- package/dist/route-content-wrapper.js +77 -0
- package/dist/route-content-wrapper.js.map +1 -0
- package/dist/route-definition.d.ts +421 -0
- package/dist/route-definition.d.ts.map +1 -0
- package/dist/route-definition.js +868 -0
- package/dist/route-definition.js.map +1 -0
- package/dist/route-map-builder.d.ts +155 -0
- package/dist/route-map-builder.d.ts.map +1 -0
- package/dist/route-map-builder.js +237 -0
- package/dist/route-map-builder.js.map +1 -0
- package/dist/route-types.d.ts +165 -0
- package/dist/route-types.d.ts.map +1 -0
- package/dist/route-types.js +7 -0
- package/dist/route-types.js.map +1 -0
- package/dist/router/__tests__/handler-context.test.d.ts +2 -0
- package/dist/router/__tests__/handler-context.test.d.ts.map +1 -0
- package/dist/router/__tests__/handler-context.test.js +65 -0
- package/dist/router/__tests__/handler-context.test.js.map +1 -0
- package/dist/router/__tests__/loader-cycle-detection.test.d.ts +2 -0
- package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +1 -0
- package/dist/router/__tests__/loader-cycle-detection.test.js +221 -0
- package/dist/router/__tests__/loader-cycle-detection.test.js.map +1 -0
- package/dist/router/__tests__/match-context.test.d.ts +2 -0
- package/dist/router/__tests__/match-context.test.d.ts.map +1 -0
- package/dist/router/__tests__/match-context.test.js +92 -0
- package/dist/router/__tests__/match-context.test.js.map +1 -0
- package/dist/router/__tests__/match-pipelines.test.d.ts +2 -0
- package/dist/router/__tests__/match-pipelines.test.d.ts.map +1 -0
- package/dist/router/__tests__/match-pipelines.test.js +417 -0
- package/dist/router/__tests__/match-pipelines.test.js.map +1 -0
- package/dist/router/__tests__/match-result.test.d.ts +2 -0
- package/dist/router/__tests__/match-result.test.d.ts.map +1 -0
- package/dist/router/__tests__/match-result.test.js +457 -0
- package/dist/router/__tests__/match-result.test.js.map +1 -0
- package/dist/router/__tests__/on-error.test.d.ts +2 -0
- package/dist/router/__tests__/on-error.test.d.ts.map +1 -0
- package/dist/router/__tests__/on-error.test.js +678 -0
- package/dist/router/__tests__/on-error.test.js.map +1 -0
- package/dist/router/__tests__/pattern-matching.test.d.ts +2 -0
- package/dist/router/__tests__/pattern-matching.test.d.ts.map +1 -0
- package/dist/router/__tests__/pattern-matching.test.js +629 -0
- package/dist/router/__tests__/pattern-matching.test.js.map +1 -0
- package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +2 -0
- package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +1 -0
- package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +155 -0
- package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +1 -0
- package/dist/router/error-handling.d.ts +77 -0
- package/dist/router/error-handling.d.ts.map +1 -0
- package/dist/router/error-handling.js +202 -0
- package/dist/router/error-handling.js.map +1 -0
- package/dist/router/handler-context.d.ts +20 -0
- package/dist/router/handler-context.d.ts.map +1 -0
- package/dist/router/handler-context.js +198 -0
- package/dist/router/handler-context.js.map +1 -0
- package/dist/router/intercept-resolution.d.ts +66 -0
- package/dist/router/intercept-resolution.d.ts.map +1 -0
- package/dist/router/intercept-resolution.js +246 -0
- package/dist/router/intercept-resolution.js.map +1 -0
- package/dist/router/loader-resolution.d.ts +64 -0
- package/dist/router/loader-resolution.d.ts.map +1 -0
- package/dist/router/loader-resolution.js +284 -0
- package/dist/router/loader-resolution.js.map +1 -0
- package/dist/router/logging.d.ts +15 -0
- package/dist/router/logging.d.ts.map +1 -0
- package/dist/router/logging.js +99 -0
- package/dist/router/logging.js.map +1 -0
- package/dist/router/manifest.d.ts +22 -0
- package/dist/router/manifest.d.ts.map +1 -0
- package/dist/router/manifest.js +181 -0
- package/dist/router/manifest.js.map +1 -0
- package/dist/router/match-api.d.ts +35 -0
- package/dist/router/match-api.d.ts.map +1 -0
- package/dist/router/match-api.js +406 -0
- package/dist/router/match-api.js.map +1 -0
- package/dist/router/match-context.d.ts +206 -0
- package/dist/router/match-context.d.ts.map +1 -0
- package/dist/router/match-context.js +17 -0
- package/dist/router/match-context.js.map +1 -0
- package/dist/router/match-middleware/background-revalidation.d.ts +127 -0
- package/dist/router/match-middleware/background-revalidation.d.ts.map +1 -0
- package/dist/router/match-middleware/background-revalidation.js +75 -0
- package/dist/router/match-middleware/background-revalidation.js.map +1 -0
- package/dist/router/match-middleware/cache-lookup.d.ts +112 -0
- package/dist/router/match-middleware/cache-lookup.d.ts.map +1 -0
- package/dist/router/match-middleware/cache-lookup.js +257 -0
- package/dist/router/match-middleware/cache-lookup.js.map +1 -0
- package/dist/router/match-middleware/cache-store.d.ts +113 -0
- package/dist/router/match-middleware/cache-store.d.ts.map +1 -0
- package/dist/router/match-middleware/cache-store.js +108 -0
- package/dist/router/match-middleware/cache-store.js.map +1 -0
- package/dist/router/match-middleware/index.d.ts +81 -0
- package/dist/router/match-middleware/index.d.ts.map +1 -0
- package/dist/router/match-middleware/index.js +80 -0
- package/dist/router/match-middleware/index.js.map +1 -0
- package/dist/router/match-middleware/intercept-resolution.d.ts +117 -0
- package/dist/router/match-middleware/intercept-resolution.d.ts.map +1 -0
- package/dist/router/match-middleware/intercept-resolution.js +134 -0
- package/dist/router/match-middleware/intercept-resolution.js.map +1 -0
- package/dist/router/match-middleware/segment-resolution.d.ts +99 -0
- package/dist/router/match-middleware/segment-resolution.d.ts.map +1 -0
- package/dist/router/match-middleware/segment-resolution.js +53 -0
- package/dist/router/match-middleware/segment-resolution.js.map +1 -0
- package/dist/router/match-pipelines.d.ts +147 -0
- package/dist/router/match-pipelines.d.ts.map +1 -0
- package/dist/router/match-pipelines.js +82 -0
- package/dist/router/match-pipelines.js.map +1 -0
- package/dist/router/match-result.d.ts +126 -0
- package/dist/router/match-result.d.ts.map +1 -0
- package/dist/router/match-result.js +93 -0
- package/dist/router/match-result.js.map +1 -0
- package/dist/router/metrics.d.ts +20 -0
- package/dist/router/metrics.d.ts.map +1 -0
- package/dist/router/metrics.js +47 -0
- package/dist/router/metrics.js.map +1 -0
- package/dist/router/middleware.d.ts +249 -0
- package/dist/router/middleware.d.ts.map +1 -0
- package/dist/router/middleware.js +434 -0
- package/dist/router/middleware.js.map +1 -0
- package/dist/router/middleware.test.d.ts +2 -0
- package/dist/router/middleware.test.d.ts.map +1 -0
- package/dist/router/middleware.test.js +816 -0
- package/dist/router/middleware.test.js.map +1 -0
- package/dist/router/pattern-matching.d.ts +149 -0
- package/dist/router/pattern-matching.d.ts.map +1 -0
- package/dist/router/pattern-matching.js +349 -0
- package/dist/router/pattern-matching.js.map +1 -0
- package/dist/router/revalidation.d.ts +44 -0
- package/dist/router/revalidation.d.ts.map +1 -0
- package/dist/router/revalidation.js +147 -0
- package/dist/router/revalidation.js.map +1 -0
- package/dist/router/router-context.d.ts +135 -0
- package/dist/router/router-context.d.ts.map +1 -0
- package/dist/router/router-context.js +36 -0
- package/dist/router/router-context.js.map +1 -0
- package/dist/router/segment-resolution.d.ts +127 -0
- package/dist/router/segment-resolution.d.ts.map +1 -0
- package/dist/router/segment-resolution.js +919 -0
- package/dist/router/segment-resolution.js.map +1 -0
- package/dist/router/trie-matching.d.ts +40 -0
- package/dist/router/trie-matching.d.ts.map +1 -0
- package/dist/router/trie-matching.js +127 -0
- package/dist/router/trie-matching.js.map +1 -0
- package/dist/router/types.d.ts +136 -0
- package/dist/router/types.d.ts.map +1 -0
- package/dist/router/types.js +7 -0
- package/dist/router/types.js.map +1 -0
- package/dist/router.d.ts +753 -0
- package/dist/router.d.ts.map +1 -0
- package/dist/router.gen.d.ts +6 -0
- package/dist/router.gen.d.ts.map +1 -0
- package/dist/router.gen.js +6 -0
- package/dist/router.gen.js.map +1 -0
- package/dist/router.js +1304 -0
- package/dist/router.js.map +1 -0
- package/dist/rsc/__tests__/helpers.test.d.ts +2 -0
- package/dist/rsc/__tests__/helpers.test.d.ts.map +1 -0
- package/dist/rsc/__tests__/helpers.test.js +140 -0
- package/dist/rsc/__tests__/helpers.test.js.map +1 -0
- package/dist/rsc/handler.d.ts +45 -0
- package/dist/rsc/handler.d.ts.map +1 -0
- package/dist/rsc/handler.js +1172 -0
- package/dist/rsc/handler.js.map +1 -0
- package/dist/rsc/helpers.d.ts +16 -0
- package/dist/rsc/helpers.d.ts.map +1 -0
- package/dist/rsc/helpers.js +55 -0
- package/dist/rsc/helpers.js.map +1 -0
- package/dist/rsc/index.d.ts +22 -0
- package/dist/rsc/index.d.ts.map +1 -0
- package/dist/rsc/index.js +23 -0
- package/dist/rsc/index.js.map +1 -0
- package/dist/rsc/nonce.d.ts +9 -0
- package/dist/rsc/nonce.d.ts.map +1 -0
- package/dist/rsc/nonce.js +18 -0
- package/dist/rsc/nonce.js.map +1 -0
- package/dist/rsc/types.d.ts +206 -0
- package/dist/rsc/types.d.ts.map +1 -0
- package/dist/rsc/types.js +8 -0
- package/dist/rsc/types.js.map +1 -0
- package/dist/search-params.d.ts +103 -0
- package/dist/search-params.d.ts.map +1 -0
- package/dist/search-params.js +74 -0
- package/dist/search-params.js.map +1 -0
- package/dist/segment-system.d.ts +75 -0
- package/dist/segment-system.d.ts.map +1 -0
- package/dist/segment-system.js +336 -0
- package/dist/segment-system.js.map +1 -0
- package/dist/server/context.d.ts +245 -0
- package/dist/server/context.d.ts.map +1 -0
- package/dist/server/context.js +197 -0
- package/dist/server/context.js.map +1 -0
- package/dist/server/fetchable-loader-store.d.ts +18 -0
- package/dist/server/fetchable-loader-store.d.ts.map +1 -0
- package/dist/server/fetchable-loader-store.js +18 -0
- package/dist/server/fetchable-loader-store.js.map +1 -0
- package/dist/server/handle-store.d.ts +85 -0
- package/dist/server/handle-store.d.ts.map +1 -0
- package/dist/server/handle-store.js +142 -0
- package/dist/server/handle-store.js.map +1 -0
- package/dist/server/loader-registry.d.ts +55 -0
- package/dist/server/loader-registry.d.ts.map +1 -0
- package/dist/server/loader-registry.js +132 -0
- package/dist/server/loader-registry.js.map +1 -0
- package/dist/server/request-context.d.ts +226 -0
- package/dist/server/request-context.d.ts.map +1 -0
- package/dist/server/request-context.js +290 -0
- package/dist/server/request-context.js.map +1 -0
- package/dist/server/root-layout.d.ts +4 -0
- package/dist/server/root-layout.d.ts.map +1 -0
- package/dist/server/root-layout.js +5 -0
- package/dist/server/root-layout.js.map +1 -0
- package/dist/server.d.ts +15 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +20 -0
- package/dist/server.js.map +1 -0
- package/dist/ssr/__tests__/ssr-handler.test.d.ts +2 -0
- package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +1 -0
- package/dist/ssr/__tests__/ssr-handler.test.js +132 -0
- package/dist/ssr/__tests__/ssr-handler.test.js.map +1 -0
- package/dist/ssr/index.d.ts +98 -0
- package/dist/ssr/index.d.ts.map +1 -0
- package/dist/ssr/index.js +158 -0
- package/dist/ssr/index.js.map +1 -0
- package/dist/static-handler.d.ts +50 -0
- package/dist/static-handler.d.ts.map +1 -0
- package/dist/static-handler.gen.d.ts +5 -0
- package/dist/static-handler.gen.d.ts.map +1 -0
- package/dist/static-handler.gen.js +5 -0
- package/dist/static-handler.gen.js.map +1 -0
- package/dist/static-handler.js +29 -0
- package/dist/static-handler.js.map +1 -0
- package/dist/theme/ThemeProvider.d.ts +20 -0
- package/dist/theme/ThemeProvider.d.ts.map +1 -0
- package/dist/theme/ThemeProvider.js +240 -0
- package/dist/theme/ThemeProvider.js.map +1 -0
- package/dist/theme/ThemeScript.d.ts +48 -0
- package/dist/theme/ThemeScript.d.ts.map +1 -0
- package/dist/theme/ThemeScript.js +13 -0
- package/dist/theme/ThemeScript.js.map +1 -0
- package/dist/theme/__tests__/theme.test.d.ts +2 -0
- package/dist/theme/__tests__/theme.test.d.ts.map +1 -0
- package/dist/theme/__tests__/theme.test.js +103 -0
- package/dist/theme/__tests__/theme.test.js.map +1 -0
- package/dist/theme/constants.d.ts +29 -0
- package/dist/theme/constants.d.ts.map +1 -0
- package/dist/theme/constants.js +48 -0
- package/dist/theme/constants.js.map +1 -0
- package/dist/theme/index.d.ts +31 -0
- package/dist/theme/index.d.ts.map +1 -0
- package/dist/theme/index.js +36 -0
- package/dist/theme/index.js.map +1 -0
- package/dist/theme/theme-context.d.ts +40 -0
- package/dist/theme/theme-context.d.ts.map +1 -0
- package/dist/theme/theme-context.js +60 -0
- package/dist/theme/theme-context.js.map +1 -0
- package/dist/theme/theme-script.d.ts +27 -0
- package/dist/theme/theme-script.d.ts.map +1 -0
- package/dist/theme/theme-script.js +147 -0
- package/dist/theme/theme-script.js.map +1 -0
- package/dist/theme/types.d.ts +163 -0
- package/dist/theme/types.d.ts.map +1 -0
- package/dist/theme/types.js +11 -0
- package/dist/theme/types.js.map +1 -0
- package/dist/theme/use-theme.d.ts +12 -0
- package/dist/theme/use-theme.d.ts.map +1 -0
- package/dist/theme/use-theme.js +40 -0
- package/dist/theme/use-theme.js.map +1 -0
- package/dist/types.d.ts +1479 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +10 -0
- package/dist/types.js.map +1 -0
- package/dist/urls.d.ts +441 -0
- package/dist/urls.d.ts.map +1 -0
- package/dist/urls.gen.d.ts +8 -0
- package/dist/urls.gen.d.ts.map +1 -0
- package/dist/urls.gen.js +8 -0
- package/dist/urls.gen.js.map +1 -0
- package/dist/urls.js +443 -0
- package/dist/urls.js.map +1 -0
- package/dist/use-loader.d.ts +127 -0
- package/dist/use-loader.d.ts.map +1 -0
- package/dist/use-loader.js +237 -0
- package/dist/use-loader.js.map +1 -0
- package/dist/vite/__tests__/ast-handler-extract.test.d.ts +2 -0
- package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +1 -0
- package/dist/vite/__tests__/ast-handler-extract.test.js +294 -0
- package/dist/vite/__tests__/ast-handler-extract.test.js.map +1 -0
- package/dist/vite/__tests__/expose-id-utils.test.d.ts +2 -0
- package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +1 -0
- package/dist/vite/__tests__/expose-id-utils.test.js +224 -0
- package/dist/vite/__tests__/expose-id-utils.test.js.map +1 -0
- package/dist/vite/__tests__/expose-internal-ids.test.d.ts +2 -0
- package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +1 -0
- package/dist/vite/__tests__/expose-internal-ids.test.js +647 -0
- package/dist/vite/__tests__/expose-internal-ids.test.js.map +1 -0
- package/dist/vite/__tests__/expose-router-id.test.d.ts +2 -0
- package/dist/vite/__tests__/expose-router-id.test.d.ts.map +1 -0
- package/dist/vite/__tests__/expose-router-id.test.js +39 -0
- package/dist/vite/__tests__/expose-router-id.test.js.map +1 -0
- package/dist/vite/ast-handler-extract.d.ts +49 -0
- package/dist/vite/ast-handler-extract.d.ts.map +1 -0
- package/dist/vite/ast-handler-extract.js +249 -0
- package/dist/vite/ast-handler-extract.js.map +1 -0
- package/dist/vite/expose-action-id.d.ts +19 -0
- package/dist/vite/expose-action-id.d.ts.map +1 -0
- package/dist/vite/expose-action-id.js +250 -0
- package/dist/vite/expose-action-id.js.map +1 -0
- package/dist/vite/expose-id-utils.d.ts +69 -0
- package/dist/vite/expose-id-utils.d.ts.map +1 -0
- package/dist/vite/expose-id-utils.js +289 -0
- package/dist/vite/expose-id-utils.js.map +1 -0
- package/dist/vite/expose-internal-ids.d.ts +22 -0
- package/dist/vite/expose-internal-ids.d.ts.map +1 -0
- package/dist/vite/expose-internal-ids.js +886 -0
- package/dist/vite/expose-internal-ids.js.map +1 -0
- package/dist/vite/index.d.ts +149 -0
- package/dist/vite/index.d.ts.map +1 -0
- package/dist/vite/index.js +5565 -2291
- package/dist/vite/index.js.bak +5448 -0
- package/dist/vite/index.js.map +1 -0
- package/dist/vite/index.named-routes.gen.ts +103 -0
- package/dist/vite/package-resolution.d.ts +43 -0
- package/dist/vite/package-resolution.d.ts.map +1 -0
- package/{src/vite/package-resolution.ts → dist/vite/package-resolution.js} +53 -66
- package/dist/vite/package-resolution.js.map +1 -0
- package/dist/vite/plugins/cloudflare-protocol-loader-hook.mjs +76 -0
- package/dist/vite/virtual-entries.d.ts +25 -0
- package/dist/vite/virtual-entries.d.ts.map +1 -0
- package/{src/vite/virtual-entries.ts → dist/vite/virtual-entries.js} +12 -16
- package/dist/vite/virtual-entries.js.map +1 -0
- package/package.json +72 -63
- package/skills/breadcrumbs/SKILL.md +252 -0
- package/skills/cache-guide/SKILL.md +294 -0
- package/skills/caching/SKILL.md +93 -23
- package/skills/composability/SKILL.md +172 -0
- package/skills/debug-manifest/SKILL.md +12 -8
- package/skills/document-cache/SKILL.md +18 -16
- package/skills/fonts/SKILL.md +6 -4
- package/skills/handler-use/SKILL.md +362 -0
- package/skills/hooks/SKILL.md +341 -71
- package/skills/host-router/SKILL.md +218 -0
- package/skills/intercept/SKILL.md +151 -8
- package/skills/layout/SKILL.md +122 -3
- package/skills/links/SKILL.md +158 -25
- package/skills/loader/SKILL.md +439 -46
- package/skills/middleware/SKILL.md +205 -37
- package/skills/migrate-nextjs/SKILL.md +560 -0
- package/skills/migrate-react-router/SKILL.md +765 -0
- package/skills/mime-routes/SKILL.md +15 -11
- package/skills/parallel/SKILL.md +263 -1
- package/skills/prerender/SKILL.md +467 -65
- package/skills/rango/SKILL.md +87 -21
- package/skills/response-routes/SKILL.md +152 -91
- package/skills/route/SKILL.md +281 -14
- package/skills/router-setup/SKILL.md +210 -32
- package/skills/streams-and-websockets/SKILL.md +283 -0
- package/skills/theme/SKILL.md +9 -8
- package/skills/typesafety/SKILL.md +327 -86
- package/skills/use-cache/SKILL.md +324 -0
- package/src/__internal.ts +102 -4
- package/src/bin/rango.ts +312 -15
- package/src/browser/action-coordinator.ts +97 -0
- package/src/browser/action-response-classifier.ts +99 -0
- package/src/browser/app-shell.ts +52 -0
- package/src/browser/app-version.ts +14 -0
- package/src/browser/event-controller.ts +92 -64
- package/src/browser/history-state.ts +80 -0
- package/src/browser/intercept-utils.ts +52 -0
- package/src/browser/link-interceptor.ts +24 -4
- package/src/browser/logging.ts +55 -0
- package/src/browser/merge-segment-loaders.ts +20 -12
- package/src/browser/navigation-bridge.ts +367 -561
- package/src/browser/navigation-client.ts +228 -70
- package/src/browser/navigation-store.ts +97 -55
- package/src/browser/navigation-transaction.ts +297 -0
- package/src/browser/network-error-handler.ts +61 -0
- package/src/browser/partial-update.ts +362 -316
- package/src/browser/prefetch/cache.ts +314 -0
- package/src/browser/prefetch/fetch.ts +282 -0
- package/src/browser/prefetch/observer.ts +65 -0
- package/src/browser/prefetch/policy.ts +48 -0
- package/src/browser/prefetch/queue.ts +191 -0
- package/src/browser/prefetch/resource-ready.ts +77 -0
- package/src/browser/rango-state.ts +152 -0
- package/src/browser/react/Link.tsx +255 -71
- package/src/browser/react/NavigationProvider.tsx +132 -17
- package/src/browser/react/context.ts +11 -0
- package/src/browser/react/filter-segment-order.ts +11 -0
- package/src/browser/react/index.ts +12 -12
- package/src/browser/react/location-state-shared.ts +95 -53
- package/src/browser/react/location-state.ts +60 -15
- package/src/browser/react/mount-context.ts +6 -1
- package/src/browser/react/nonce-context.ts +23 -0
- package/src/browser/react/shallow-equal.ts +27 -0
- package/src/browser/react/use-action.ts +29 -51
- package/src/browser/react/use-client-cache.ts +5 -3
- package/src/browser/react/use-handle.ts +30 -120
- package/src/browser/react/use-link-status.ts +6 -5
- package/src/browser/react/use-navigation.ts +44 -65
- package/src/browser/react/use-params.ts +75 -0
- package/src/browser/react/use-pathname.ts +47 -0
- package/src/browser/react/use-router.ts +83 -0
- package/src/browser/react/use-search-params.ts +56 -0
- package/src/browser/react/use-segments.ts +80 -97
- package/src/browser/response-adapter.ts +73 -0
- package/src/browser/rsc-router.tsx +246 -64
- package/src/browser/scroll-restoration.ts +127 -52
- package/src/browser/segment-reconciler.ts +243 -0
- package/src/browser/segment-structure-assert.ts +16 -0
- package/src/browser/server-action-bridge.ts +510 -603
- package/src/browser/shallow.ts +6 -1
- package/src/browser/types.ts +152 -48
- package/src/browser/validate-redirect-origin.ts +29 -0
- package/src/build/generate-manifest.ts +84 -23
- package/src/build/generate-route-types.ts +39 -752
- package/src/build/index.ts +6 -5
- package/src/build/route-trie.ts +83 -31
- package/src/build/route-types/ast-helpers.ts +25 -0
- package/src/build/route-types/ast-route-extraction.ts +98 -0
- package/src/build/route-types/codegen.ts +102 -0
- package/src/build/route-types/include-resolution.ts +418 -0
- package/src/build/route-types/param-extraction.ts +48 -0
- package/src/build/route-types/per-module-writer.ts +128 -0
- package/src/build/route-types/router-processing.ts +618 -0
- package/src/build/route-types/scan-filter.ts +85 -0
- package/src/build/runtime-discovery.ts +231 -0
- package/src/cache/background-task.ts +34 -0
- package/src/cache/cache-key-utils.ts +44 -0
- package/src/cache/cache-policy.ts +125 -0
- package/src/cache/cache-runtime.ts +342 -0
- package/src/cache/cache-scope.ts +167 -307
- package/src/cache/cf/cf-cache-store.ts +573 -21
- package/src/cache/cf/index.ts +13 -3
- package/src/cache/document-cache.ts +116 -77
- package/src/cache/handle-capture.ts +81 -0
- package/src/cache/handle-snapshot.ts +41 -0
- package/src/cache/index.ts +1 -15
- package/src/cache/memory-segment-store.ts +191 -13
- package/src/cache/profile-registry.ts +73 -0
- package/src/cache/read-through-swr.ts +134 -0
- package/src/cache/segment-codec.ts +256 -0
- package/src/cache/taint.ts +153 -0
- package/src/cache/types.ts +72 -122
- package/src/client.rsc.tsx +3 -1
- package/src/client.tsx +113 -301
- package/src/component-utils.ts +4 -4
- package/src/components/DefaultDocument.tsx +5 -1
- package/src/context-var.ts +156 -0
- package/src/debug.ts +19 -9
- package/src/errors.ts +77 -7
- package/src/handle.ts +55 -10
- package/src/handles/MetaTags.tsx +73 -20
- package/src/handles/breadcrumbs.ts +66 -0
- package/src/handles/index.ts +1 -0
- package/src/handles/meta.ts +30 -13
- package/src/host/cookie-handler.ts +21 -15
- package/src/host/errors.ts +8 -8
- package/src/host/index.ts +4 -7
- package/src/host/pattern-matcher.ts +27 -27
- package/src/host/router.ts +61 -39
- package/src/host/testing.ts +8 -8
- package/src/host/types.ts +15 -7
- package/src/host/utils.ts +1 -1
- package/src/href-client.ts +65 -45
- package/src/index.rsc.ts +138 -21
- package/src/index.ts +206 -51
- package/src/internal-debug.ts +11 -0
- package/src/loader.rsc.ts +25 -143
- package/src/loader.ts +27 -10
- package/src/network-error-thrower.tsx +3 -1
- package/src/outlet-context.ts +1 -1
- package/src/outlet-provider.tsx +45 -0
- package/src/prerender/param-hash.ts +4 -2
- package/src/prerender/store.ts +159 -13
- package/src/prerender.ts +397 -29
- package/src/response-utils.ts +28 -0
- package/src/reverse.ts +209 -121
- package/src/root-error-boundary.tsx +41 -29
- package/src/route-content-wrapper.tsx +7 -4
- package/src/route-definition/dsl-helpers.ts +1134 -0
- package/src/route-definition/helper-factories.ts +200 -0
- package/src/route-definition/helpers-types.ts +478 -0
- package/src/route-definition/index.ts +55 -0
- package/src/route-definition/redirect.ts +101 -0
- package/src/route-definition/resolve-handler-use.ts +155 -0
- package/src/route-definition.ts +1 -1431
- package/src/route-map-builder.ts +162 -123
- package/src/route-name.ts +53 -0
- package/src/route-types.ts +66 -9
- package/src/router/content-negotiation.ts +215 -0
- package/src/router/debug-manifest.ts +72 -0
- package/src/router/error-handling.ts +9 -9
- package/src/router/find-match.ts +160 -0
- package/src/router/handler-context.ts +455 -86
- package/src/router/intercept-resolution.ts +35 -20
- package/src/router/lazy-includes.ts +237 -0
- package/src/router/loader-resolution.ts +359 -128
- package/src/router/logging.ts +251 -0
- package/src/router/manifest.ts +98 -32
- package/src/router/match-api.ts +195 -261
- package/src/router/match-context.ts +4 -2
- package/src/router/match-handlers.ts +440 -0
- package/src/router/match-middleware/background-revalidation.ts +108 -93
- package/src/router/match-middleware/cache-lookup.ts +415 -86
- package/src/router/match-middleware/cache-store.ts +91 -29
- package/src/router/match-middleware/intercept-resolution.ts +48 -21
- package/src/router/match-middleware/segment-resolution.ts +73 -9
- package/src/router/match-pipelines.ts +10 -45
- package/src/router/match-result.ts +135 -35
- package/src/router/metrics.ts +240 -15
- package/src/router/middleware-cookies.ts +55 -0
- package/src/router/middleware-types.ts +200 -0
- package/src/router/middleware.ts +373 -371
- package/src/router/navigation-snapshot.ts +182 -0
- package/src/router/pattern-matching.ts +251 -44
- package/src/router/prerender-match.ts +502 -0
- package/src/router/preview-match.ts +98 -0
- package/src/router/request-classification.ts +310 -0
- package/src/router/revalidation.ts +152 -39
- package/src/router/route-snapshot.ts +245 -0
- package/src/router/router-context.ts +41 -21
- package/src/router/router-interfaces.ts +484 -0
- package/src/router/router-options.ts +618 -0
- package/src/router/router-registry.ts +24 -0
- package/src/router/segment-resolution/fresh.ts +748 -0
- package/src/router/segment-resolution/helpers.ts +268 -0
- package/src/router/segment-resolution/loader-cache.ts +199 -0
- package/src/router/segment-resolution/revalidation.ts +1384 -0
- package/src/router/segment-resolution/static-store.ts +67 -0
- package/src/router/segment-resolution.ts +21 -1315
- package/src/router/segment-wrappers.ts +291 -0
- package/src/router/telemetry-otel.ts +299 -0
- package/src/router/telemetry.ts +300 -0
- package/src/router/timeout.ts +148 -0
- package/src/router/trie-matching.ts +103 -30
- package/src/router/types.ts +17 -9
- package/src/router/url-params.ts +49 -0
- package/src/router.ts +647 -1988
- package/src/rsc/handler-context.ts +45 -0
- package/src/rsc/handler.ts +864 -1114
- package/src/rsc/helpers.ts +181 -19
- package/src/rsc/index.ts +0 -20
- package/src/rsc/loader-fetch.ts +229 -0
- package/src/rsc/manifest-init.ts +90 -0
- package/src/rsc/nonce.ts +14 -0
- package/src/rsc/origin-guard.ts +141 -0
- package/src/rsc/progressive-enhancement.ts +393 -0
- package/src/rsc/response-error.ts +37 -0
- package/src/rsc/response-route-handler.ts +360 -0
- package/src/rsc/rsc-rendering.ts +253 -0
- package/src/rsc/runtime-warnings.ts +42 -0
- package/src/rsc/server-action.ts +358 -0
- package/src/rsc/ssr-setup.ts +128 -0
- package/src/rsc/types.ts +46 -11
- package/src/search-params.ts +230 -0
- package/src/segment-content-promise.ts +67 -0
- package/src/segment-loader-promise.ts +122 -0
- package/src/segment-system.tsx +134 -36
- package/src/server/context.ts +333 -59
- package/src/server/cookie-store.ts +190 -0
- package/src/server/fetchable-loader-store.ts +37 -0
- package/src/server/handle-store.ts +113 -15
- package/src/server/loader-registry.ts +24 -64
- package/src/server/request-context.ts +603 -109
- package/src/server.ts +35 -155
- package/src/ssr/index.tsx +103 -30
- package/src/static-handler.ts +126 -0
- package/src/theme/ThemeProvider.tsx +21 -15
- package/src/theme/ThemeScript.tsx +5 -5
- package/src/theme/constants.ts +5 -2
- package/src/theme/index.ts +4 -14
- package/src/theme/theme-context.ts +4 -30
- package/src/theme/theme-script.ts +21 -18
- package/src/types/boundaries.ts +158 -0
- package/src/types/cache-types.ts +198 -0
- package/src/types/error-types.ts +192 -0
- package/src/types/global-namespace.ts +100 -0
- package/src/types/handler-context.ts +759 -0
- package/src/types/index.ts +88 -0
- package/src/types/loader-types.ts +209 -0
- package/src/types/request-scope.ts +126 -0
- package/src/types/route-config.ts +170 -0
- package/src/types/route-entry.ts +120 -0
- package/src/types/segments.ts +150 -0
- package/src/types.ts +1 -1757
- package/src/urls/include-helper.ts +207 -0
- package/src/urls/index.ts +53 -0
- package/src/urls/path-helper-types.ts +372 -0
- package/src/urls/path-helper.ts +364 -0
- package/src/urls/pattern-types.ts +107 -0
- package/src/urls/response-types.ts +108 -0
- package/src/urls/type-extraction.ts +372 -0
- package/src/urls/urls-function.ts +98 -0
- package/src/urls.ts +1 -1282
- package/src/use-loader.tsx +161 -81
- package/src/vite/debug.ts +184 -0
- package/src/vite/discovery/bundle-postprocess.ts +181 -0
- package/src/vite/discovery/discover-routers.ts +376 -0
- package/src/vite/discovery/prerender-collection.ts +486 -0
- package/src/vite/discovery/route-types-writer.ts +258 -0
- package/src/vite/discovery/self-gen-tracking.ts +47 -0
- package/src/vite/discovery/state.ts +117 -0
- package/src/vite/discovery/virtual-module-codegen.ts +203 -0
- package/src/vite/index.ts +15 -1963
- package/src/vite/plugin-types.ts +103 -0
- package/src/vite/plugins/cjs-to-esm.ts +98 -0
- package/src/vite/plugins/client-ref-dedup.ts +131 -0
- package/src/vite/plugins/client-ref-hashing.ts +117 -0
- package/src/vite/plugins/cloudflare-protocol-loader-hook.d.mts +23 -0
- package/src/vite/plugins/cloudflare-protocol-loader-hook.mjs +76 -0
- package/src/vite/plugins/cloudflare-protocol-stub.ts +214 -0
- package/src/vite/{expose-action-id.ts → plugins/expose-action-id.ts} +107 -64
- package/src/vite/plugins/expose-id-utils.ts +299 -0
- package/src/vite/plugins/expose-ids/export-analysis.ts +296 -0
- package/src/vite/plugins/expose-ids/handler-transform.ts +209 -0
- package/src/vite/plugins/expose-ids/loader-transform.ts +74 -0
- package/src/vite/plugins/expose-ids/router-transform.ts +127 -0
- package/src/vite/plugins/expose-ids/types.ts +45 -0
- package/src/vite/plugins/expose-internal-ids.ts +816 -0
- package/src/vite/plugins/performance-tracks.ts +96 -0
- package/src/vite/plugins/refresh-cmd.ts +127 -0
- package/src/vite/plugins/use-cache-transform.ts +336 -0
- package/src/vite/plugins/version-injector.ts +83 -0
- package/src/vite/plugins/version-plugin.ts +266 -0
- package/src/vite/plugins/virtual-entries.ts +123 -0
- package/src/vite/plugins/virtual-stub-plugin.ts +29 -0
- package/src/vite/rango.ts +497 -0
- package/src/vite/router-discovery.ts +1111 -0
- package/src/vite/utils/ast-handler-extract.ts +517 -0
- package/src/vite/utils/banner.ts +36 -0
- package/src/vite/utils/bundle-analysis.ts +137 -0
- package/src/vite/utils/manifest-utils.ts +70 -0
- package/src/vite/utils/package-resolution.ts +161 -0
- package/src/vite/utils/prerender-utils.ts +221 -0
- package/src/vite/utils/shared-utils.ts +170 -0
- package/CLAUDE.md +0 -43
- package/src/browser/lru-cache.ts +0 -69
- package/src/browser/request-controller.ts +0 -164
- package/src/cache/memory-store.ts +0 -253
- package/src/router.gen.ts +0 -6
- package/src/urls.gen.ts +0 -8
- package/src/vite/expose-handle-id.ts +0 -209
- package/src/vite/expose-loader-id.ts +0 -426
- package/src/vite/expose-location-state-id.ts +0 -177
- package/src/vite/expose-prerender-handler-id.ts +0 -429
- /package/src/vite/{version.d.ts → plugins/version.d.ts} +0 -0
|
@@ -13,13 +13,43 @@
|
|
|
13
13
|
import { AsyncLocalStorage } from "node:async_hooks";
|
|
14
14
|
import type { CookieOptions } from "../router/middleware.js";
|
|
15
15
|
import type { LoaderDefinition, LoaderContext } from "../types.js";
|
|
16
|
+
import type { ScopedReverseFunction } from "../reverse.js";
|
|
17
|
+
import type {
|
|
18
|
+
DefaultEnv,
|
|
19
|
+
DefaultReverseRouteMap,
|
|
20
|
+
DefaultRouteName,
|
|
21
|
+
} from "../types/global-namespace.js";
|
|
16
22
|
import type { Handle } from "../handle.js";
|
|
17
|
-
import {
|
|
23
|
+
import {
|
|
24
|
+
type ContextVar,
|
|
25
|
+
contextGet,
|
|
26
|
+
contextSet,
|
|
27
|
+
isNonCacheable,
|
|
28
|
+
} from "../context-var.js";
|
|
29
|
+
import {
|
|
30
|
+
createHandleStore,
|
|
31
|
+
buildHandleSnapshot,
|
|
32
|
+
type HandleStore,
|
|
33
|
+
type HandleData,
|
|
34
|
+
} from "./handle-store.js";
|
|
18
35
|
import { isHandle } from "../handle.js";
|
|
19
|
-
import { track } from "./context.js";
|
|
36
|
+
import { track, type MetricsStore } from "./context.js";
|
|
37
|
+
import { getFetchableLoader } from "./fetchable-loader-store.js";
|
|
20
38
|
import type { SegmentCacheStore } from "../cache/types.js";
|
|
21
39
|
import type { Theme, ResolvedThemeConfig } from "../theme/types.js";
|
|
40
|
+
import type { ExecutionContext, RequestScope } from "../types/request-scope.js";
|
|
41
|
+
import { fireAndForgetWaitUntil } from "../types/request-scope.js";
|
|
22
42
|
import { THEME_COOKIE } from "../theme/constants.js";
|
|
43
|
+
import type { LocationStateEntry } from "../browser/react/location-state-shared.js";
|
|
44
|
+
import { NOCACHE_SYMBOL, assertNotInsideCacheExec } from "../cache/taint.js";
|
|
45
|
+
import { isInsideCacheScope } from "./context.js";
|
|
46
|
+
import {
|
|
47
|
+
createReverseFunction,
|
|
48
|
+
stripInternalParams,
|
|
49
|
+
} from "../router/handler-context.js";
|
|
50
|
+
import { getGlobalRouteMap, isRouteRootScoped } from "../route-map-builder.js";
|
|
51
|
+
import { invariant } from "../errors.js";
|
|
52
|
+
import { isAutoGeneratedRouteName } from "../route-name.js";
|
|
23
53
|
|
|
24
54
|
/**
|
|
25
55
|
* Unified request context available via getRequestContext()
|
|
@@ -28,46 +58,50 @@ import { THEME_COOKIE } from "../theme/constants.js";
|
|
|
28
58
|
* Use this when you need access to request data outside of route handlers.
|
|
29
59
|
*/
|
|
30
60
|
export interface RequestContext<
|
|
31
|
-
TEnv =
|
|
61
|
+
TEnv = DefaultEnv,
|
|
32
62
|
TParams = Record<string, string>,
|
|
33
|
-
> {
|
|
34
|
-
/**
|
|
35
|
-
|
|
36
|
-
/** Original HTTP request */
|
|
37
|
-
request: Request;
|
|
38
|
-
/** Parsed URL (system params like _rsc* are NOT filtered here) */
|
|
39
|
-
url: URL;
|
|
40
|
-
/** URL pathname */
|
|
41
|
-
pathname: string;
|
|
42
|
-
/** URL search params (system params like _rsc* are NOT filtered here) */
|
|
43
|
-
searchParams: URLSearchParams;
|
|
44
|
-
/** Variables set by middleware (same as ctx.var) */
|
|
45
|
-
var: Record<string, any>;
|
|
63
|
+
> extends RequestScope<TEnv> {
|
|
64
|
+
/** @internal Shared variable backing store for ctx.get()/ctx.set(). */
|
|
65
|
+
_variables: Record<string, any>;
|
|
46
66
|
/** Get a variable set by middleware */
|
|
47
|
-
get:
|
|
67
|
+
get: {
|
|
68
|
+
<T>(contextVar: ContextVar<T>): T | undefined;
|
|
69
|
+
<K extends string>(key: K): any;
|
|
70
|
+
};
|
|
48
71
|
/** Set a variable (shared with middleware and handlers) */
|
|
49
|
-
set:
|
|
72
|
+
set: {
|
|
73
|
+
<T>(
|
|
74
|
+
contextVar: ContextVar<T>,
|
|
75
|
+
value: T,
|
|
76
|
+
options?: { cache?: boolean },
|
|
77
|
+
): void;
|
|
78
|
+
<K extends string>(key: K, value: any, options?: { cache?: boolean }): void;
|
|
79
|
+
};
|
|
50
80
|
/**
|
|
51
81
|
* Route params (populated after route matching)
|
|
52
82
|
* Initially empty, then set to matched params
|
|
53
83
|
*/
|
|
54
84
|
params: TParams;
|
|
55
|
-
/**
|
|
56
|
-
|
|
57
|
-
* Headers set here are merged into the final response
|
|
58
|
-
*/
|
|
59
|
-
res: Response;
|
|
85
|
+
/** @internal Stub response for collecting headers/cookies. Use ctx.headers or ctx.header() instead. */
|
|
86
|
+
readonly res: Response;
|
|
60
87
|
|
|
61
|
-
/** Get a cookie value
|
|
88
|
+
/** @internal Get a cookie value (effective: request + response mutations). Use cookies().get() instead. */
|
|
62
89
|
cookie(name: string): string | undefined;
|
|
63
|
-
/** Get all cookies
|
|
90
|
+
/** @internal Get all cookies (effective merged view). Use cookies().getAll() instead. */
|
|
64
91
|
cookies(): Record<string, string>;
|
|
65
|
-
/** Set a cookie on the response */
|
|
92
|
+
/** @internal Set a cookie on the response. Use cookies().set() instead. */
|
|
66
93
|
setCookie(name: string, value: string, options?: CookieOptions): void;
|
|
67
|
-
/** Delete a cookie */
|
|
68
|
-
deleteCookie(
|
|
94
|
+
/** @internal Delete a cookie. Use cookies().delete() instead. */
|
|
95
|
+
deleteCookie(
|
|
96
|
+
name: string,
|
|
97
|
+
options?: Pick<CookieOptions, "domain" | "path">,
|
|
98
|
+
): void;
|
|
69
99
|
/** Set a response header */
|
|
70
100
|
header(name: string, value: string): void;
|
|
101
|
+
/** Set the response status code */
|
|
102
|
+
setStatus(status: number): void;
|
|
103
|
+
/** @internal Set status bypassing cache-exec guard (for framework error handling) */
|
|
104
|
+
_setStatus(status: number): void;
|
|
71
105
|
|
|
72
106
|
/**
|
|
73
107
|
* Access loader data or push handle data.
|
|
@@ -89,10 +123,12 @@ export interface RequestContext<
|
|
|
89
123
|
* ```
|
|
90
124
|
*/
|
|
91
125
|
use: {
|
|
92
|
-
<T, TLoaderParams = any>(
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
126
|
+
<T, TLoaderParams = any>(
|
|
127
|
+
loader: LoaderDefinition<T, TLoaderParams>,
|
|
128
|
+
): Promise<T>;
|
|
129
|
+
<TData, TAccumulated = TData[]>(
|
|
130
|
+
handle: Handle<TData, TAccumulated>,
|
|
131
|
+
): (data: TData | Promise<TData> | (() => Promise<TData>)) => void;
|
|
96
132
|
};
|
|
97
133
|
|
|
98
134
|
/** HTTP method (GET, POST, PUT, PATCH, DELETE, etc.) */
|
|
@@ -104,19 +140,11 @@ export interface RequestContext<
|
|
|
104
140
|
/** @internal Cache store for segment caching (optional, used by CacheScope) */
|
|
105
141
|
_cacheStore?: SegmentCacheStore;
|
|
106
142
|
|
|
107
|
-
/**
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
* @example
|
|
113
|
-
* ```typescript
|
|
114
|
-
* ctx.waitUntil(async () => {
|
|
115
|
-
* await cacheStore.set(key, data, ttl);
|
|
116
|
-
* });
|
|
117
|
-
* ```
|
|
118
|
-
*/
|
|
119
|
-
waitUntil(fn: () => Promise<void>): void;
|
|
143
|
+
/** @internal Cache profiles for "use cache" profile resolution (per-router) */
|
|
144
|
+
_cacheProfiles?: Record<
|
|
145
|
+
string,
|
|
146
|
+
import("../cache/profile-registry.js").CacheProfile
|
|
147
|
+
>;
|
|
120
148
|
|
|
121
149
|
/**
|
|
122
150
|
* Register a callback to run when the response is created.
|
|
@@ -177,8 +205,166 @@ export interface RequestContext<
|
|
|
177
205
|
|
|
178
206
|
/** @internal Theme configuration (null if theme not enabled) */
|
|
179
207
|
_themeConfig?: ResolvedThemeConfig | null;
|
|
208
|
+
|
|
209
|
+
/**
|
|
210
|
+
* Attach location state entries to the current response.
|
|
211
|
+
*
|
|
212
|
+
* For partial (SPA) requests, the state is included in the RSC payload
|
|
213
|
+
* metadata and merged into history.pushState on the client. For redirect
|
|
214
|
+
* responses, the state travels through the redirect payload so the target
|
|
215
|
+
* page can read it via useLocationState.
|
|
216
|
+
*
|
|
217
|
+
* Multiple calls accumulate entries.
|
|
218
|
+
*
|
|
219
|
+
* @example
|
|
220
|
+
* ```typescript
|
|
221
|
+
* ctx.setLocationState(Flash({ text: "Item saved!" }));
|
|
222
|
+
* ```
|
|
223
|
+
*/
|
|
224
|
+
setLocationState(entries: LocationStateEntry | LocationStateEntry[]): void;
|
|
225
|
+
|
|
226
|
+
/** @internal Accumulated location state entries */
|
|
227
|
+
_locationState?: LocationStateEntry[];
|
|
228
|
+
|
|
229
|
+
/**
|
|
230
|
+
* The matched route name, if the route has an explicit name.
|
|
231
|
+
* Undefined before route matching or for unnamed routes.
|
|
232
|
+
* Includes the namespace prefix from include() (e.g., "blog.post").
|
|
233
|
+
*/
|
|
234
|
+
routeName?: DefaultRouteName;
|
|
235
|
+
|
|
236
|
+
/**
|
|
237
|
+
* Generate URLs from route names.
|
|
238
|
+
* Uses the global route map. After route matching, scoped (`.name`) resolution
|
|
239
|
+
* works within the matched include() scope.
|
|
240
|
+
*/
|
|
241
|
+
reverse: ScopedReverseFunction<
|
|
242
|
+
Record<string, string>,
|
|
243
|
+
DefaultReverseRouteMap
|
|
244
|
+
>;
|
|
245
|
+
|
|
246
|
+
/** @internal Route name from route matching, used for scoped reverse resolution */
|
|
247
|
+
_routeName?: string;
|
|
248
|
+
|
|
249
|
+
/** @internal Previous route key (from the navigation source), used for revalidation */
|
|
250
|
+
_prevRouteKey?: string;
|
|
251
|
+
|
|
252
|
+
/**
|
|
253
|
+
* @internal Render barrier for experimental `rendered()` API.
|
|
254
|
+
* Resolves when all non-loader segments have settled and handle data
|
|
255
|
+
* is available. Used by DSL loaders that call `ctx.rendered()`.
|
|
256
|
+
*/
|
|
257
|
+
_renderBarrier: Promise<void>;
|
|
258
|
+
|
|
259
|
+
/**
|
|
260
|
+
* @internal Resolve the render barrier. Accepts resolved segments, filters
|
|
261
|
+
* out loaders, and captures non-loader segment IDs as the handle ordering.
|
|
262
|
+
* Called after segment resolution (fresh) or handle replay (cache/prerender).
|
|
263
|
+
*/
|
|
264
|
+
_resolveRenderBarrier: (
|
|
265
|
+
segments: Array<{ type: string; id: string }>,
|
|
266
|
+
) => void;
|
|
267
|
+
|
|
268
|
+
/**
|
|
269
|
+
* @internal Segment order at barrier resolution time, used by loader
|
|
270
|
+
* ctx.use(handle) to collect handle data in correct order.
|
|
271
|
+
*/
|
|
272
|
+
_renderBarrierSegmentOrder?: string[];
|
|
273
|
+
|
|
274
|
+
/**
|
|
275
|
+
* @internal Set to true when the matched entry tree contains any `loading()`
|
|
276
|
+
* entries (streaming). Used by rendered() to fail fast.
|
|
277
|
+
*/
|
|
278
|
+
_treeHasStreaming?: boolean;
|
|
279
|
+
|
|
280
|
+
/**
|
|
281
|
+
* @internal Loader IDs that have called rendered() and are waiting for the
|
|
282
|
+
* barrier. Used to detect deadlocks when a handler tries to await the same
|
|
283
|
+
* loader via ctx.use(Loader).
|
|
284
|
+
*/
|
|
285
|
+
_renderBarrierWaiters?: Set<string>;
|
|
286
|
+
|
|
287
|
+
/**
|
|
288
|
+
* @internal Loader IDs that handlers have started awaiting via ctx.use().
|
|
289
|
+
* Used for bidirectional deadlock detection: if a loader later calls
|
|
290
|
+
* rendered() and a handler already awaits it, we can detect the deadlock.
|
|
291
|
+
*/
|
|
292
|
+
_handlerLoaderDeps?: Set<string>;
|
|
293
|
+
|
|
294
|
+
/**
|
|
295
|
+
* @internal Cached HandleData snapshot built at barrier resolution time.
|
|
296
|
+
* Avoids rebuilding the snapshot on every loader ctx.use(handle) call.
|
|
297
|
+
*/
|
|
298
|
+
_renderBarrierHandleSnapshot?: HandleData;
|
|
299
|
+
|
|
300
|
+
/** @internal Per-request error dedup set for onError reporting */
|
|
301
|
+
_reportedErrors: WeakSet<object>;
|
|
302
|
+
|
|
303
|
+
/**
|
|
304
|
+
* @internal Report a non-fatal background error through the router's
|
|
305
|
+
* onError callback. Wired by the RSC handler / router during request
|
|
306
|
+
* creation. Cache-runtime and other subsystems call this to surface
|
|
307
|
+
* errors without failing the response.
|
|
308
|
+
*/
|
|
309
|
+
_reportBackgroundError?: (error: unknown, category: string) => void;
|
|
310
|
+
|
|
311
|
+
/** @internal Per-request debug performance override (set via ctx.debugPerformance()) */
|
|
312
|
+
_debugPerformance?: boolean;
|
|
313
|
+
|
|
314
|
+
/** @internal Request-scoped performance metrics store */
|
|
315
|
+
_metricsStore?: MetricsStore;
|
|
316
|
+
|
|
317
|
+
/** @internal Router basename for this request (used by redirect()) */
|
|
318
|
+
_basename?: string;
|
|
319
|
+
|
|
320
|
+
/**
|
|
321
|
+
* @internal RouteSnapshot from classifyRequest, reused by match/matchPartial
|
|
322
|
+
* to avoid a second resolveRoute call. Cleared on HMR invalidation.
|
|
323
|
+
*/
|
|
324
|
+
_classifiedRoute?: import("../router/route-snapshot.js").RouteSnapshot;
|
|
180
325
|
}
|
|
181
326
|
|
|
327
|
+
/**
|
|
328
|
+
* Public view of RequestContext, without internal methods and fields.
|
|
329
|
+
*
|
|
330
|
+
* This is the type exported to library consumers. Internal code should
|
|
331
|
+
* use the full RequestContext interface directly.
|
|
332
|
+
*/
|
|
333
|
+
export type PublicRequestContext<
|
|
334
|
+
TEnv = DefaultEnv,
|
|
335
|
+
TParams = Record<string, string>,
|
|
336
|
+
> = Omit<
|
|
337
|
+
RequestContext<TEnv, TParams>,
|
|
338
|
+
| "cookie"
|
|
339
|
+
| "cookies"
|
|
340
|
+
| "setCookie"
|
|
341
|
+
| "deleteCookie"
|
|
342
|
+
| "_handleStore"
|
|
343
|
+
| "_cacheStore"
|
|
344
|
+
| "_cacheProfiles"
|
|
345
|
+
| "_onResponseCallbacks"
|
|
346
|
+
| "_themeConfig"
|
|
347
|
+
| "_locationState"
|
|
348
|
+
| "_routeName"
|
|
349
|
+
| "_prevRouteKey"
|
|
350
|
+
| "_reportedErrors"
|
|
351
|
+
| "_renderBarrier"
|
|
352
|
+
| "_resolveRenderBarrier"
|
|
353
|
+
| "_renderBarrierSegmentOrder"
|
|
354
|
+
| "_treeHasStreaming"
|
|
355
|
+
| "_renderBarrierWaiters"
|
|
356
|
+
| "_handlerLoaderDeps"
|
|
357
|
+
| "_renderBarrierHandleSnapshot"
|
|
358
|
+
| "_reportBackgroundError"
|
|
359
|
+
| "_debugPerformance"
|
|
360
|
+
| "_metricsStore"
|
|
361
|
+
| "_basename"
|
|
362
|
+
| "_setStatus"
|
|
363
|
+
| "_variables"
|
|
364
|
+
| "_classifiedRoute"
|
|
365
|
+
| "res"
|
|
366
|
+
>;
|
|
367
|
+
|
|
182
368
|
// AsyncLocalStorage instance for request context
|
|
183
369
|
const requestContextStorage = new AsyncLocalStorage<RequestContext<any>>();
|
|
184
370
|
|
|
@@ -188,16 +374,33 @@ const requestContextStorage = new AsyncLocalStorage<RequestContext<any>>();
|
|
|
188
374
|
*/
|
|
189
375
|
export function runWithRequestContext<TEnv, T>(
|
|
190
376
|
context: RequestContext<TEnv>,
|
|
191
|
-
fn: () => T
|
|
377
|
+
fn: () => T,
|
|
192
378
|
): T {
|
|
193
379
|
return requestContextStorage.run(context, fn);
|
|
194
380
|
}
|
|
195
381
|
|
|
196
382
|
/**
|
|
197
383
|
* Get the current request context
|
|
198
|
-
*
|
|
384
|
+
* Throws if called outside of a request context
|
|
199
385
|
*/
|
|
200
|
-
export function getRequestContext<TEnv =
|
|
386
|
+
export function getRequestContext<TEnv = DefaultEnv>(): RequestContext<TEnv> {
|
|
387
|
+
const ctx = requestContextStorage.getStore() as
|
|
388
|
+
| RequestContext<TEnv>
|
|
389
|
+
| undefined;
|
|
390
|
+
invariant(
|
|
391
|
+
ctx,
|
|
392
|
+
"getRequestContext() called outside of a request context. " +
|
|
393
|
+
"This function must be called from within a route handler, loader, middleware, " +
|
|
394
|
+
"server action, or server component.",
|
|
395
|
+
);
|
|
396
|
+
return ctx;
|
|
397
|
+
}
|
|
398
|
+
|
|
399
|
+
/**
|
|
400
|
+
* @internal Get the request context without throwing — for internal code that
|
|
401
|
+
* may run outside a request context (cache stores, optional handle lookups, etc.)
|
|
402
|
+
*/
|
|
403
|
+
export function _getRequestContext<TEnv = DefaultEnv>():
|
|
201
404
|
| RequestContext<TEnv>
|
|
202
405
|
| undefined {
|
|
203
406
|
return requestContextStorage.getStore() as RequestContext<TEnv> | undefined;
|
|
@@ -205,38 +408,71 @@ export function getRequestContext<TEnv = unknown>():
|
|
|
205
408
|
|
|
206
409
|
/**
|
|
207
410
|
* Update params on the current request context
|
|
208
|
-
* Called after route matching to populate route params
|
|
411
|
+
* Called after route matching to populate route params and route name
|
|
209
412
|
*/
|
|
210
|
-
export function setRequestContextParams(
|
|
413
|
+
export function setRequestContextParams(
|
|
414
|
+
params: Record<string, string>,
|
|
415
|
+
routeName?: string,
|
|
416
|
+
): void {
|
|
211
417
|
const ctx = requestContextStorage.getStore();
|
|
212
418
|
if (ctx) {
|
|
213
419
|
ctx.params = params;
|
|
420
|
+
if (routeName !== undefined) {
|
|
421
|
+
ctx._routeName = routeName;
|
|
422
|
+
ctx.routeName = (
|
|
423
|
+
routeName && !isAutoGeneratedRouteName(routeName)
|
|
424
|
+
? routeName
|
|
425
|
+
: undefined
|
|
426
|
+
) as DefaultRouteName | undefined;
|
|
427
|
+
}
|
|
428
|
+
// Update reverse with scoped resolution now that route is known
|
|
429
|
+
ctx.reverse = createReverseFunction(
|
|
430
|
+
getGlobalRouteMap(),
|
|
431
|
+
routeName,
|
|
432
|
+
params,
|
|
433
|
+
routeName ? isRouteRootScoped(routeName) : undefined,
|
|
434
|
+
);
|
|
214
435
|
}
|
|
215
436
|
}
|
|
216
437
|
|
|
217
438
|
/**
|
|
218
|
-
*
|
|
219
|
-
*
|
|
439
|
+
* Store the previous route key on the request context.
|
|
440
|
+
* Called during partial-match context creation to make the navigation source
|
|
441
|
+
* route key available for revalidation and intercept evaluation.
|
|
442
|
+
* @internal
|
|
220
443
|
*/
|
|
221
|
-
export function
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
);
|
|
444
|
+
export function setRequestContextPrevRouteKey(
|
|
445
|
+
prevRouteKey: string | undefined,
|
|
446
|
+
): void {
|
|
447
|
+
const ctx = requestContextStorage.getStore();
|
|
448
|
+
if (ctx && prevRouteKey !== undefined) {
|
|
449
|
+
ctx._prevRouteKey = prevRouteKey;
|
|
228
450
|
}
|
|
229
|
-
return ctx;
|
|
230
451
|
}
|
|
231
452
|
|
|
232
453
|
/**
|
|
233
|
-
*
|
|
454
|
+
* Get accumulated location state entries from the current request context.
|
|
455
|
+
* Returns undefined if no state has been set.
|
|
456
|
+
*
|
|
457
|
+
* @internal Used by the RSC handler to include state in payload metadata.
|
|
234
458
|
*/
|
|
235
|
-
export
|
|
236
|
-
|
|
237
|
-
|
|
459
|
+
export function getLocationState(): LocationStateEntry[] | undefined {
|
|
460
|
+
const ctx = getRequestContext();
|
|
461
|
+
return ctx?._locationState;
|
|
238
462
|
}
|
|
239
463
|
|
|
464
|
+
/**
|
|
465
|
+
* Get the current request context, throwing if not available
|
|
466
|
+
* @deprecated Use getRequestContext() directly — it now throws if outside context
|
|
467
|
+
*/
|
|
468
|
+
export function requireRequestContext<
|
|
469
|
+
TEnv = DefaultEnv,
|
|
470
|
+
>(): RequestContext<TEnv> {
|
|
471
|
+
return getRequestContext<TEnv>();
|
|
472
|
+
}
|
|
473
|
+
|
|
474
|
+
export type { ExecutionContext };
|
|
475
|
+
|
|
240
476
|
/**
|
|
241
477
|
* Options for creating a request context
|
|
242
478
|
*/
|
|
@@ -245,8 +481,15 @@ export interface CreateRequestContextOptions<TEnv> {
|
|
|
245
481
|
request: Request;
|
|
246
482
|
url: URL;
|
|
247
483
|
variables: Record<string, any>;
|
|
484
|
+
/** Optional initial response stub headers/status to seed effective cookie reads */
|
|
485
|
+
initialResponse?: Response;
|
|
248
486
|
/** Optional cache store for segment caching (used by CacheScope) */
|
|
249
487
|
cacheStore?: SegmentCacheStore;
|
|
488
|
+
/** Optional cache profiles for "use cache" resolution (per-router) */
|
|
489
|
+
cacheProfiles?: Record<
|
|
490
|
+
string,
|
|
491
|
+
import("../cache/profile-registry.js").CacheProfile
|
|
492
|
+
>;
|
|
250
493
|
/** Optional Cloudflare execution context for waitUntil support */
|
|
251
494
|
executionContext?: ExecutionContext;
|
|
252
495
|
/** Optional theme configuration (enables ctx.theme and ctx.setTheme) */
|
|
@@ -262,20 +505,37 @@ export interface CreateRequestContextOptions<TEnv> {
|
|
|
262
505
|
* - Passed to handlers as ctx
|
|
263
506
|
*/
|
|
264
507
|
export function createRequestContext<TEnv>(
|
|
265
|
-
options: CreateRequestContextOptions<TEnv
|
|
508
|
+
options: CreateRequestContextOptions<TEnv>,
|
|
266
509
|
): RequestContext<TEnv> {
|
|
267
|
-
const {
|
|
510
|
+
const {
|
|
511
|
+
env,
|
|
512
|
+
request,
|
|
513
|
+
url,
|
|
514
|
+
variables,
|
|
515
|
+
initialResponse,
|
|
516
|
+
cacheStore,
|
|
517
|
+
cacheProfiles,
|
|
518
|
+
executionContext,
|
|
519
|
+
themeConfig,
|
|
520
|
+
} = options;
|
|
268
521
|
const cookieHeader = request.headers.get("Cookie");
|
|
269
522
|
let parsedCookies: Record<string, string> | null = null;
|
|
270
523
|
|
|
271
|
-
// Create stub response for collecting headers/cookies
|
|
272
|
-
|
|
524
|
+
// Create stub response for collecting headers/cookies.
|
|
525
|
+
// All cookie/header mutations go here; cookie reads derive from it.
|
|
526
|
+
let stubResponse = initialResponse
|
|
527
|
+
? new Response(null, {
|
|
528
|
+
status: initialResponse.status,
|
|
529
|
+
statusText: initialResponse.statusText,
|
|
530
|
+
headers: new Headers(initialResponse.headers),
|
|
531
|
+
})
|
|
532
|
+
: new Response(null, { status: 200 });
|
|
273
533
|
|
|
274
534
|
// Create handle store and loader memoization for this request
|
|
275
535
|
const handleStore = createHandleStore();
|
|
276
536
|
const loaderPromises = new Map<string, Promise<any>>();
|
|
277
537
|
|
|
278
|
-
// Lazy parse cookies
|
|
538
|
+
// Lazy parse cookies from the original Cookie header
|
|
279
539
|
const getParsedCookies = (): Record<string, string> => {
|
|
280
540
|
if (!parsedCookies) {
|
|
281
541
|
parsedCookies = parseCookiesFromHeader(cookieHeader);
|
|
@@ -283,11 +543,47 @@ export function createRequestContext<TEnv>(
|
|
|
283
543
|
return parsedCookies;
|
|
284
544
|
};
|
|
285
545
|
|
|
546
|
+
// Cached response cookie mutations — invalidated on setCookie/deleteCookie/setTheme
|
|
547
|
+
let responseCookieCache: Map<string, string | null> | null = null;
|
|
548
|
+
const getResponseCookies = (): Map<string, string | null> => {
|
|
549
|
+
if (!responseCookieCache) {
|
|
550
|
+
responseCookieCache = parseResponseCookies(stubResponse);
|
|
551
|
+
}
|
|
552
|
+
return responseCookieCache;
|
|
553
|
+
};
|
|
554
|
+
const invalidateResponseCookieCache = () => {
|
|
555
|
+
responseCookieCache = null;
|
|
556
|
+
};
|
|
557
|
+
|
|
558
|
+
// Guard: throw if a response-level side effect is called inside a cache() scope.
|
|
559
|
+
// Uses ALS to detect the scope (set during segment resolution).
|
|
560
|
+
function assertNotInsideCacheScopeALS(methodName: string): void {
|
|
561
|
+
if (isInsideCacheScope()) {
|
|
562
|
+
throw new Error(
|
|
563
|
+
`ctx.${methodName}() cannot be called inside a cache() boundary. ` +
|
|
564
|
+
`On cache hit the handler is skipped, so this side effect would be lost. ` +
|
|
565
|
+
`Move ctx.${methodName}() to a middleware or layout outside the cache() scope.`,
|
|
566
|
+
);
|
|
567
|
+
}
|
|
568
|
+
}
|
|
569
|
+
|
|
570
|
+
// Effective cookie read: response stub Set-Cookie wins, then original header.
|
|
571
|
+
// The stub IS the source of truth for same-request mutations.
|
|
572
|
+
const effectiveCookie = (name: string): string | undefined => {
|
|
573
|
+
const mutations = getResponseCookies();
|
|
574
|
+
if (mutations.has(name)) {
|
|
575
|
+
const v = mutations.get(name);
|
|
576
|
+
return v === null ? undefined : v;
|
|
577
|
+
}
|
|
578
|
+
return getParsedCookies()[name];
|
|
579
|
+
};
|
|
580
|
+
|
|
286
581
|
// Theme helpers (only used when themeConfig is provided)
|
|
287
582
|
const getTheme = (): Theme | undefined => {
|
|
288
583
|
if (!themeConfig) return undefined;
|
|
289
584
|
|
|
290
|
-
|
|
585
|
+
// Use overlay-aware read so setTheme() in the same request is reflected
|
|
586
|
+
const stored = effectiveCookie(themeConfig.storageKey);
|
|
291
587
|
if (stored) {
|
|
292
588
|
// Validate stored value
|
|
293
589
|
if (stored === "system" && themeConfig.enableSystem) {
|
|
@@ -305,65 +601,129 @@ export function createRequestContext<TEnv>(
|
|
|
305
601
|
|
|
306
602
|
// Validate theme value
|
|
307
603
|
if (theme !== "system" && !themeConfig.themes.includes(theme)) {
|
|
308
|
-
console.warn(
|
|
604
|
+
console.warn(
|
|
605
|
+
`[Theme] Invalid theme value: "${theme}". Valid values: system, ${themeConfig.themes.join(", ")}`,
|
|
606
|
+
);
|
|
309
607
|
return;
|
|
310
608
|
}
|
|
311
609
|
|
|
312
|
-
//
|
|
610
|
+
// Write to stub — effectiveCookie() will pick it up on next read
|
|
313
611
|
stubResponse.headers.append(
|
|
314
612
|
"Set-Cookie",
|
|
315
613
|
serializeCookieValue(themeConfig.storageKey, theme, {
|
|
316
614
|
path: THEME_COOKIE.path,
|
|
317
615
|
maxAge: THEME_COOKIE.maxAge,
|
|
318
616
|
sameSite: THEME_COOKIE.sameSite,
|
|
319
|
-
})
|
|
617
|
+
}),
|
|
320
618
|
);
|
|
619
|
+
invalidateResponseCookieCache();
|
|
321
620
|
};
|
|
322
621
|
|
|
622
|
+
// Strip internal _rsc* params so userland sees a clean URL.
|
|
623
|
+
const cleanUrl = stripInternalParams(url);
|
|
624
|
+
|
|
323
625
|
// Build the context object first (without use), then add use
|
|
324
626
|
const ctx: RequestContext<TEnv> = {
|
|
325
627
|
env,
|
|
326
628
|
request,
|
|
327
|
-
url,
|
|
629
|
+
url: cleanUrl,
|
|
630
|
+
originalUrl: new URL(request.url),
|
|
328
631
|
pathname: url.pathname,
|
|
329
|
-
searchParams:
|
|
330
|
-
|
|
331
|
-
get:
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
632
|
+
searchParams: cleanUrl.searchParams,
|
|
633
|
+
_variables: variables,
|
|
634
|
+
get: ((keyOrVar: any) => {
|
|
635
|
+
if (isNonCacheable(variables, keyOrVar) && isInsideCacheScope()) {
|
|
636
|
+
throw new Error(
|
|
637
|
+
`ctx.get() for a non-cacheable variable cannot be called inside a cache() boundary. ` +
|
|
638
|
+
`The variable was created with { cache: false } or set with { cache: false }, ` +
|
|
639
|
+
`and its value would be stale on cache hit. Move the read outside the cached scope.`,
|
|
640
|
+
);
|
|
641
|
+
}
|
|
642
|
+
return contextGet(variables, keyOrVar);
|
|
643
|
+
}) as RequestContext<TEnv>["get"],
|
|
644
|
+
set: ((keyOrVar: any, value: any, options?: any) => {
|
|
645
|
+
assertNotInsideCacheExec(ctx, "set");
|
|
646
|
+
contextSet(variables, keyOrVar, value, options);
|
|
647
|
+
}) as RequestContext<TEnv>["set"],
|
|
335
648
|
params: {} as Record<string, string>,
|
|
336
|
-
|
|
649
|
+
|
|
650
|
+
get res(): Response {
|
|
651
|
+
return stubResponse;
|
|
652
|
+
},
|
|
653
|
+
set res(_: Response) {
|
|
654
|
+
throw new Error(
|
|
655
|
+
"ctx.res is read-only. Use ctx.header() to set response headers, or cookies() for cookie mutations.",
|
|
656
|
+
);
|
|
657
|
+
},
|
|
337
658
|
|
|
338
659
|
cookie(name: string): string | undefined {
|
|
339
|
-
return
|
|
660
|
+
return effectiveCookie(name);
|
|
340
661
|
},
|
|
341
662
|
|
|
342
663
|
cookies(): Record<string, string> {
|
|
343
|
-
|
|
664
|
+
const parsed = getParsedCookies();
|
|
665
|
+
const mutations = getResponseCookies();
|
|
666
|
+
if (mutations.size === 0) return { ...parsed };
|
|
667
|
+
// Build result without delete (avoids V8 dictionary-mode de-opt)
|
|
668
|
+
const deleted = new Set<string>();
|
|
669
|
+
for (const [k, v] of mutations) {
|
|
670
|
+
if (v === null) deleted.add(k);
|
|
671
|
+
}
|
|
672
|
+
const result: Record<string, string> = {};
|
|
673
|
+
for (const key of Object.keys(parsed)) {
|
|
674
|
+
if (!deleted.has(key)) result[key] = parsed[key];
|
|
675
|
+
}
|
|
676
|
+
for (const [k, v] of mutations) {
|
|
677
|
+
if (v !== null) result[k] = v;
|
|
678
|
+
}
|
|
679
|
+
return result;
|
|
344
680
|
},
|
|
345
681
|
|
|
346
682
|
setCookie(name: string, value: string, options?: CookieOptions): void {
|
|
683
|
+
assertNotInsideCacheExec(ctx, "setCookie");
|
|
684
|
+
assertNotInsideCacheScopeALS("setCookie");
|
|
347
685
|
stubResponse.headers.append(
|
|
348
686
|
"Set-Cookie",
|
|
349
|
-
serializeCookieValue(name, value, options)
|
|
687
|
+
serializeCookieValue(name, value, options),
|
|
350
688
|
);
|
|
689
|
+
invalidateResponseCookieCache();
|
|
351
690
|
},
|
|
352
691
|
|
|
353
692
|
deleteCookie(
|
|
354
693
|
name: string,
|
|
355
|
-
options?: Pick<CookieOptions, "domain" | "path"
|
|
694
|
+
options?: Pick<CookieOptions, "domain" | "path">,
|
|
356
695
|
): void {
|
|
696
|
+
assertNotInsideCacheExec(ctx, "deleteCookie");
|
|
697
|
+
assertNotInsideCacheScopeALS("deleteCookie");
|
|
357
698
|
stubResponse.headers.append(
|
|
358
699
|
"Set-Cookie",
|
|
359
|
-
serializeCookieValue(name, "", { ...options, maxAge: 0 })
|
|
700
|
+
serializeCookieValue(name, "", { ...options, maxAge: 0 }),
|
|
360
701
|
);
|
|
702
|
+
invalidateResponseCookieCache();
|
|
361
703
|
},
|
|
362
704
|
|
|
363
705
|
header(name: string, value: string): void {
|
|
706
|
+
assertNotInsideCacheExec(ctx, "header");
|
|
707
|
+
assertNotInsideCacheScopeALS("header");
|
|
364
708
|
stubResponse.headers.set(name, value);
|
|
365
709
|
},
|
|
366
710
|
|
|
711
|
+
setStatus(status: number): void {
|
|
712
|
+
assertNotInsideCacheExec(ctx, "setStatus");
|
|
713
|
+
assertNotInsideCacheScopeALS("setStatus");
|
|
714
|
+
stubResponse = new Response(null, {
|
|
715
|
+
status,
|
|
716
|
+
headers: stubResponse.headers,
|
|
717
|
+
});
|
|
718
|
+
},
|
|
719
|
+
|
|
720
|
+
_setStatus(status: number): void {
|
|
721
|
+
stubResponse = new Response(null, {
|
|
722
|
+
status,
|
|
723
|
+
headers: stubResponse.headers,
|
|
724
|
+
});
|
|
725
|
+
},
|
|
726
|
+
|
|
367
727
|
// Placeholder - will be replaced below
|
|
368
728
|
use: null as any,
|
|
369
729
|
|
|
@@ -371,29 +731,102 @@ export function createRequestContext<TEnv>(
|
|
|
371
731
|
|
|
372
732
|
_handleStore: handleStore,
|
|
373
733
|
_cacheStore: cacheStore,
|
|
734
|
+
_cacheProfiles: cacheProfiles,
|
|
374
735
|
|
|
375
736
|
waitUntil(fn: () => Promise<void>): void {
|
|
376
737
|
if (executionContext?.waitUntil) {
|
|
377
|
-
// Cloudflare Workers: use native waitUntil
|
|
378
738
|
executionContext.waitUntil(fn());
|
|
379
739
|
} else {
|
|
380
|
-
|
|
381
|
-
fn().catch((err) => console.error("[waitUntil] Background task failed:", err));
|
|
740
|
+
fireAndForgetWaitUntil(fn);
|
|
382
741
|
}
|
|
383
742
|
},
|
|
384
743
|
|
|
744
|
+
executionContext,
|
|
745
|
+
|
|
385
746
|
_onResponseCallbacks: [],
|
|
386
747
|
|
|
387
748
|
onResponse(callback: (response: Response) => Response): void {
|
|
749
|
+
assertNotInsideCacheExec(ctx, "onResponse");
|
|
750
|
+
assertNotInsideCacheScopeALS("onResponse");
|
|
388
751
|
this._onResponseCallbacks.push(callback);
|
|
389
752
|
},
|
|
390
753
|
|
|
391
754
|
// Theme properties (only set when themeConfig is provided)
|
|
392
|
-
theme
|
|
393
|
-
|
|
755
|
+
get theme() {
|
|
756
|
+
return themeConfig ? getTheme() : undefined;
|
|
757
|
+
},
|
|
758
|
+
setTheme: themeConfig
|
|
759
|
+
? (theme: Theme) => {
|
|
760
|
+
assertNotInsideCacheExec(ctx, "setTheme");
|
|
761
|
+
setTheme(theme);
|
|
762
|
+
}
|
|
763
|
+
: undefined,
|
|
394
764
|
_themeConfig: themeConfig,
|
|
765
|
+
|
|
766
|
+
setLocationState(entries: LocationStateEntry | LocationStateEntry[]): void {
|
|
767
|
+
assertNotInsideCacheExec(ctx, "setLocationState");
|
|
768
|
+
const arr = Array.isArray(entries) ? entries : [entries];
|
|
769
|
+
this._locationState = this._locationState
|
|
770
|
+
? [...this._locationState, ...arr]
|
|
771
|
+
: arr;
|
|
772
|
+
},
|
|
773
|
+
_locationState: undefined,
|
|
774
|
+
|
|
775
|
+
_reportedErrors: new WeakSet<object>(),
|
|
776
|
+
_metricsStore: undefined,
|
|
777
|
+
|
|
778
|
+
// Render barrier: deferred promise resolved after non-loader segments settle.
|
|
779
|
+
_renderBarrier: null as any, // set below
|
|
780
|
+
_resolveRenderBarrier: null as any, // set below
|
|
781
|
+
_renderBarrierSegmentOrder: undefined,
|
|
782
|
+
|
|
783
|
+
reverse: createReverseFunction(getGlobalRouteMap(), undefined, {}),
|
|
395
784
|
};
|
|
396
785
|
|
|
786
|
+
// Lazy render barrier: only allocate the Promise when a loader actually
|
|
787
|
+
// calls rendered(). Requests that don't use rendered() pay zero cost.
|
|
788
|
+
let barrierResolved = false;
|
|
789
|
+
let resolveBarrier: (() => void) | undefined;
|
|
790
|
+
ctx._renderBarrier = null as any; // lazy — created on first access
|
|
791
|
+
ctx._resolveRenderBarrier = (
|
|
792
|
+
segments: Array<{ type: string; id: string }>,
|
|
793
|
+
) => {
|
|
794
|
+
if (barrierResolved) return;
|
|
795
|
+
barrierResolved = true;
|
|
796
|
+
const segOrder = segments
|
|
797
|
+
.filter((s) => s.type !== "loader")
|
|
798
|
+
.map((s) => s.id);
|
|
799
|
+
ctx._renderBarrierSegmentOrder = segOrder;
|
|
800
|
+
// Build and cache handle snapshot so loader ctx.use(handle) calls
|
|
801
|
+
// don't rebuild it on every invocation.
|
|
802
|
+
ctx._renderBarrierHandleSnapshot = buildHandleSnapshot(
|
|
803
|
+
handleStore,
|
|
804
|
+
segOrder,
|
|
805
|
+
);
|
|
806
|
+
ctx._renderBarrierWaiters = undefined;
|
|
807
|
+
ctx._handlerLoaderDeps = undefined;
|
|
808
|
+
if (resolveBarrier) resolveBarrier();
|
|
809
|
+
};
|
|
810
|
+
Object.defineProperty(ctx, "_renderBarrier", {
|
|
811
|
+
get() {
|
|
812
|
+
// Barrier already resolved (cache/prerender hit) or first lazy access.
|
|
813
|
+
// Either way, replace the getter with a concrete value to avoid
|
|
814
|
+
// repeated Promise.resolve() allocations on subsequent reads.
|
|
815
|
+
const p = barrierResolved
|
|
816
|
+
? Promise.resolve()
|
|
817
|
+
: new Promise<void>((resolve) => {
|
|
818
|
+
resolveBarrier = resolve;
|
|
819
|
+
});
|
|
820
|
+
Object.defineProperty(ctx, "_renderBarrier", {
|
|
821
|
+
value: p,
|
|
822
|
+
writable: false,
|
|
823
|
+
configurable: false,
|
|
824
|
+
});
|
|
825
|
+
return p;
|
|
826
|
+
},
|
|
827
|
+
configurable: true,
|
|
828
|
+
});
|
|
829
|
+
|
|
397
830
|
// Now create use() with access to ctx
|
|
398
831
|
ctx.use = createUseFunction({
|
|
399
832
|
handleStore,
|
|
@@ -401,14 +834,53 @@ export function createRequestContext<TEnv>(
|
|
|
401
834
|
getContext: () => ctx,
|
|
402
835
|
});
|
|
403
836
|
|
|
837
|
+
// Brand with taint symbol so "use cache" excludes ctx from cache keys
|
|
838
|
+
(ctx as any)[NOCACHE_SYMBOL] = true;
|
|
404
839
|
return ctx;
|
|
405
840
|
}
|
|
406
841
|
|
|
842
|
+
/**
|
|
843
|
+
* Parse Set-Cookie headers from a response into effective cookie state.
|
|
844
|
+
* Returns a map of cookie name -> value (string) or name -> null (deleted).
|
|
845
|
+
* Last-write-wins: later Set-Cookie entries for the same name overwrite earlier ones.
|
|
846
|
+
* Max-Age=0 is treated as a delete.
|
|
847
|
+
*/
|
|
848
|
+
const MAX_AGE_ZERO_RE = /;\s*Max-Age\s*=\s*0/i;
|
|
849
|
+
|
|
850
|
+
function parseResponseCookies(response: Response): Map<string, string | null> {
|
|
851
|
+
const result = new Map<string, string | null>();
|
|
852
|
+
const setCookies = response.headers.getSetCookie();
|
|
853
|
+
|
|
854
|
+
for (const header of setCookies) {
|
|
855
|
+
// First segment before ';' is the name=value pair
|
|
856
|
+
const semiIdx = header.indexOf(";");
|
|
857
|
+
const pair = semiIdx === -1 ? header : header.substring(0, semiIdx);
|
|
858
|
+
const eqIdx = pair.indexOf("=");
|
|
859
|
+
if (eqIdx === -1) continue;
|
|
860
|
+
|
|
861
|
+
let name: string;
|
|
862
|
+
let value: string;
|
|
863
|
+
try {
|
|
864
|
+
name = decodeURIComponent(pair.substring(0, eqIdx).trim());
|
|
865
|
+
value = decodeURIComponent(pair.substring(eqIdx + 1).trim());
|
|
866
|
+
} catch {
|
|
867
|
+
// Malformed encoding — skip this entry
|
|
868
|
+
continue;
|
|
869
|
+
}
|
|
870
|
+
|
|
871
|
+
// Max-Age=0 means the cookie is being deleted
|
|
872
|
+
const isDeleted = MAX_AGE_ZERO_RE.test(header);
|
|
873
|
+
result.set(name, isDeleted ? null : value);
|
|
874
|
+
}
|
|
875
|
+
|
|
876
|
+
return result;
|
|
877
|
+
}
|
|
878
|
+
|
|
407
879
|
/**
|
|
408
880
|
* Parse cookies from Cookie header
|
|
409
881
|
*/
|
|
410
882
|
function parseCookiesFromHeader(
|
|
411
|
-
cookieHeader: string | null
|
|
883
|
+
cookieHeader: string | null,
|
|
412
884
|
): Record<string, string> {
|
|
413
885
|
if (!cookieHeader) return {};
|
|
414
886
|
|
|
@@ -418,7 +890,13 @@ function parseCookiesFromHeader(
|
|
|
418
890
|
for (const pair of pairs) {
|
|
419
891
|
const [name, ...rest] = pair.trim().split("=");
|
|
420
892
|
if (name) {
|
|
421
|
-
|
|
893
|
+
const raw = rest.join("=");
|
|
894
|
+
try {
|
|
895
|
+
cookies[name] = decodeURIComponent(raw);
|
|
896
|
+
} catch {
|
|
897
|
+
// Malformed percent-encoded value (e.g. %zz, %2) - fall back to raw value
|
|
898
|
+
cookies[name] = raw;
|
|
899
|
+
}
|
|
422
900
|
}
|
|
423
901
|
}
|
|
424
902
|
|
|
@@ -431,7 +909,7 @@ function parseCookiesFromHeader(
|
|
|
431
909
|
function serializeCookieValue(
|
|
432
910
|
name: string,
|
|
433
911
|
value: string,
|
|
434
|
-
options: CookieOptions = {}
|
|
912
|
+
options: CookieOptions = {},
|
|
435
913
|
): string {
|
|
436
914
|
let cookie = `${encodeURIComponent(name)}=${encodeURIComponent(value)}`;
|
|
437
915
|
|
|
@@ -463,7 +941,7 @@ export interface CreateUseFunctionOptions<TEnv> {
|
|
|
463
941
|
* - For handles: returns a push function to add handle data
|
|
464
942
|
*/
|
|
465
943
|
export function createUseFunction<TEnv>(
|
|
466
|
-
options: CreateUseFunctionOptions<TEnv
|
|
944
|
+
options: CreateUseFunctionOptions<TEnv>,
|
|
467
945
|
): RequestContext["use"] {
|
|
468
946
|
const { handleStore, loaderPromises, getContext } = options;
|
|
469
947
|
|
|
@@ -477,16 +955,19 @@ export function createUseFunction<TEnv>(
|
|
|
477
955
|
if (!segmentId) {
|
|
478
956
|
throw new Error(
|
|
479
957
|
`Handle "${handle.$$id}" used outside of handler context. ` +
|
|
480
|
-
`Handles must be used within route/layout handlers
|
|
958
|
+
`Handles must be used within route/layout handlers.`,
|
|
481
959
|
);
|
|
482
960
|
}
|
|
483
961
|
|
|
484
962
|
// Return a push function bound to this handle and segment
|
|
485
|
-
return (
|
|
963
|
+
return (
|
|
964
|
+
dataOrFn: unknown | Promise<unknown> | (() => Promise<unknown>),
|
|
965
|
+
) => {
|
|
486
966
|
// If it's a function, call it immediately to get the promise
|
|
487
|
-
const valueOrPromise =
|
|
488
|
-
|
|
489
|
-
|
|
967
|
+
const valueOrPromise =
|
|
968
|
+
typeof dataOrFn === "function"
|
|
969
|
+
? (dataOrFn as () => Promise<unknown>)()
|
|
970
|
+
: dataOrFn;
|
|
490
971
|
|
|
491
972
|
// Push directly - promises will be serialized by RSC and streamed
|
|
492
973
|
handleStore.push(handle.$$id, segmentId, valueOrPromise);
|
|
@@ -504,8 +985,6 @@ export function createUseFunction<TEnv>(
|
|
|
504
985
|
// Get loader function - either from loader object or fetchable registry
|
|
505
986
|
let loaderFn = loader.fn;
|
|
506
987
|
if (!loaderFn) {
|
|
507
|
-
// Lazy import to avoid circular dependency
|
|
508
|
-
const { getFetchableLoader } = require("../loader.rsc.js");
|
|
509
988
|
const fetchable = getFetchableLoader(loader.$$id);
|
|
510
989
|
if (fetchable) {
|
|
511
990
|
loaderFn = fetchable.fn;
|
|
@@ -514,7 +993,7 @@ export function createUseFunction<TEnv>(
|
|
|
514
993
|
|
|
515
994
|
if (!loaderFn) {
|
|
516
995
|
throw new Error(
|
|
517
|
-
`Loader "${loader.$$id}" has no function. This usually means the loader was defined without "use server" and the function was not included in the build
|
|
996
|
+
`Loader "${loader.$$id}" has no function. This usually means the loader was defined without "use server" and the function was not included in the build.`,
|
|
518
997
|
);
|
|
519
998
|
}
|
|
520
999
|
|
|
@@ -523,25 +1002,40 @@ export function createUseFunction<TEnv>(
|
|
|
523
1002
|
// Create loader context with recursive use() support
|
|
524
1003
|
const loaderCtx: LoaderContext<Record<string, string | undefined>, TEnv> = {
|
|
525
1004
|
params: ctx.params,
|
|
1005
|
+
routeParams: (ctx.params ?? {}) as Record<string, string>,
|
|
526
1006
|
request: ctx.request,
|
|
527
1007
|
searchParams: ctx.searchParams,
|
|
1008
|
+
search: (ctx as any).search ?? {},
|
|
528
1009
|
pathname: ctx.pathname,
|
|
529
1010
|
url: ctx.url,
|
|
1011
|
+
originalUrl: ctx.originalUrl,
|
|
530
1012
|
env: ctx.env as any,
|
|
531
|
-
|
|
1013
|
+
waitUntil: ctx.waitUntil.bind(ctx),
|
|
1014
|
+
executionContext: ctx.executionContext,
|
|
532
1015
|
get: ctx.get as any,
|
|
533
|
-
use: <TDep, TDepParams = any>(
|
|
534
|
-
dep: LoaderDefinition<TDep, TDepParams
|
|
1016
|
+
use: (<TDep, TDepParams = any>(
|
|
1017
|
+
dep: LoaderDefinition<TDep, TDepParams>,
|
|
535
1018
|
): Promise<TDep> => {
|
|
536
1019
|
// Recursive call - will start dep loader if not already started
|
|
537
1020
|
return ctx.use(dep);
|
|
538
|
-
},
|
|
1021
|
+
}) as LoaderContext["use"],
|
|
539
1022
|
method: "GET",
|
|
540
1023
|
body: undefined,
|
|
1024
|
+
reverse: createReverseFunction(
|
|
1025
|
+
getGlobalRouteMap(),
|
|
1026
|
+
ctx._routeName,
|
|
1027
|
+
ctx.params as Record<string, string>,
|
|
1028
|
+
ctx._routeName ? isRouteRootScoped(ctx._routeName) : undefined,
|
|
1029
|
+
),
|
|
1030
|
+
rendered: () => {
|
|
1031
|
+
throw new Error(
|
|
1032
|
+
`ctx.rendered() is only available in DSL loaders (registered via loader() in urls()). ` +
|
|
1033
|
+
`It cannot be used from request-context loaders or server actions.`,
|
|
1034
|
+
);
|
|
1035
|
+
},
|
|
541
1036
|
};
|
|
542
1037
|
|
|
543
|
-
|
|
544
|
-
const doneLoader = track(`loader:${loader.$$id}`);
|
|
1038
|
+
const doneLoader = track(`loader:${loader.$$id}`, 2);
|
|
545
1039
|
const promise = Promise.resolve(loaderFn(loaderCtx)).finally(() => {
|
|
546
1040
|
doneLoader();
|
|
547
1041
|
});
|