vinext 0.0.30 → 0.0.31
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/README.md +12 -6
- package/dist/build/prerender.d.ts +188 -0
- package/dist/build/prerender.js +675 -0
- package/dist/build/prerender.js.map +1 -0
- package/dist/build/report.d.ts +45 -46
- package/dist/build/report.js +247 -276
- package/dist/build/report.js.map +1 -1
- package/dist/build/run-prerender.d.ts +62 -0
- package/dist/build/run-prerender.js +183 -0
- package/dist/build/run-prerender.js.map +1 -0
- package/dist/build/server-manifest.d.ts +19 -0
- package/dist/build/server-manifest.js +29 -0
- package/dist/build/server-manifest.js.map +1 -0
- package/dist/build/static-export.d.ts +51 -66
- package/dist/build/static-export.js +51 -545
- package/dist/build/static-export.js.map +1 -1
- package/dist/check.d.ts +26 -24
- package/dist/check.js +591 -571
- package/dist/check.js.map +1 -1
- package/dist/cli.d.ts +1 -15
- package/dist/cli.js +430 -491
- package/dist/cli.js.map +1 -1
- package/dist/client/entry.d.ts +1 -2
- package/dist/client/entry.js +49 -62
- package/dist/client/entry.js.map +1 -1
- package/dist/client/validate-module-path.d.ts +4 -1
- package/dist/client/validate-module-path.js +23 -28
- package/dist/client/validate-module-path.js.map +1 -1
- package/dist/client/vinext-next-data.d.ts +15 -20
- package/dist/client/vinext-next-data.js +0 -1
- package/dist/cloudflare/index.d.ts +3 -8
- package/dist/cloudflare/index.js +3 -8
- package/dist/cloudflare/kv-cache-handler.d.ts +95 -105
- package/dist/cloudflare/kv-cache-handler.js +354 -380
- package/dist/cloudflare/kv-cache-handler.js.map +1 -1
- package/dist/cloudflare/tpr.d.ts +36 -34
- package/dist/cloudflare/tpr.js +460 -603
- package/dist/cloudflare/tpr.js.map +1 -1
- package/dist/config/config-matchers.d.ts +31 -40
- package/dist/config/config-matchers.js +727 -936
- package/dist/config/config-matchers.js.map +1 -1
- package/dist/config/dotenv.d.ts +18 -11
- package/dist/config/dotenv.js +79 -84
- package/dist/config/dotenv.js.map +1 -1
- package/dist/config/next-config.d.ts +156 -146
- package/dist/config/next-config.js +374 -464
- package/dist/config/next-config.js.map +1 -1
- package/dist/deploy.d.ts +87 -96
- package/dist/deploy.js +490 -628
- package/dist/deploy.js.map +1 -1
- package/dist/entries/app-browser-entry.d.ts +4 -1
- package/dist/entries/app-browser-entry.js +12 -8
- package/dist/entries/app-browser-entry.js.map +1 -1
- package/dist/entries/app-rsc-entry.d.ts +33 -20
- package/dist/entries/app-rsc-entry.js +442 -211
- package/dist/entries/app-rsc-entry.js.map +1 -1
- package/dist/entries/app-ssr-entry.d.ts +9 -1
- package/dist/entries/app-ssr-entry.js +61 -28
- package/dist/entries/app-ssr-entry.js.map +1 -1
- package/dist/entries/pages-client-entry.d.ts +6 -2
- package/dist/entries/pages-client-entry.js +30 -33
- package/dist/entries/pages-client-entry.js.map +1 -1
- package/dist/entries/pages-entry-helpers.d.ts +5 -1
- package/dist/entries/pages-entry-helpers.js +17 -14
- package/dist/entries/pages-entry-helpers.js.map +1 -1
- package/dist/entries/pages-server-entry.d.ts +6 -2
- package/dist/entries/pages-server-entry.js +84 -113
- package/dist/entries/pages-server-entry.js.map +1 -1
- package/dist/index.d.ts +82 -62
- package/dist/index.js +2172 -3133
- package/dist/index.js.map +1 -1
- package/dist/init.d.ts +40 -37
- package/dist/init.js +201 -258
- package/dist/init.js.map +1 -1
- package/dist/plugins/async-hooks-stub.d.ts +7 -3
- package/dist/plugins/async-hooks-stub.js +39 -42
- package/dist/plugins/async-hooks-stub.js.map +1 -1
- package/dist/plugins/client-reference-dedup.d.ts +7 -3
- package/dist/plugins/client-reference-dedup.js +63 -88
- package/dist/plugins/client-reference-dedup.js.map +1 -1
- package/dist/routing/app-router.d.ts +100 -96
- package/dist/routing/app-router.js +560 -670
- package/dist/routing/app-router.js.map +1 -1
- package/dist/routing/file-matcher.d.ts +18 -15
- package/dist/routing/file-matcher.js +65 -65
- package/dist/routing/file-matcher.js.map +1 -1
- package/dist/routing/pages-router.d.ts +23 -24
- package/dist/routing/pages-router.js +147 -172
- package/dist/routing/pages-router.js.map +1 -1
- package/dist/routing/route-trie.d.ts +23 -20
- package/dist/routing/route-trie.js +131 -151
- package/dist/routing/route-trie.js.map +1 -1
- package/dist/routing/route-validation.d.ts +5 -2
- package/dist/routing/route-validation.js +98 -130
- package/dist/routing/route-validation.js.map +1 -1
- package/dist/routing/utils.d.ts +10 -7
- package/dist/routing/utils.js +75 -111
- package/dist/routing/utils.js.map +1 -1
- package/dist/server/api-handler.d.ts +8 -13
- package/dist/server/api-handler.js +161 -193
- package/dist/server/api-handler.js.map +1 -1
- package/dist/server/app-router-entry.d.ts +6 -16
- package/dist/server/app-router-entry.js +26 -54
- package/dist/server/app-router-entry.js.map +1 -1
- package/dist/server/dev-module-runner.d.ts +11 -64
- package/dist/server/dev-module-runner.js +89 -101
- package/dist/server/dev-module-runner.js.map +1 -1
- package/dist/server/dev-origin-check.d.ts +12 -10
- package/dist/server/dev-origin-check.js +98 -108
- package/dist/server/dev-origin-check.js.map +1 -1
- package/dist/server/dev-server.d.ts +17 -14
- package/dist/server/dev-server.js +542 -869
- package/dist/server/dev-server.js.map +1 -1
- package/dist/server/html.d.ts +4 -1
- package/dist/server/html.js +25 -26
- package/dist/server/html.js.map +1 -1
- package/dist/server/image-optimization.d.ts +31 -28
- package/dist/server/image-optimization.js +181 -210
- package/dist/server/image-optimization.js.map +1 -1
- package/dist/server/instrumentation.d.ts +25 -22
- package/dist/server/instrumentation.js +110 -122
- package/dist/server/instrumentation.js.map +1 -1
- package/dist/server/isr-cache.d.ts +16 -26
- package/dist/server/isr-cache.js +106 -128
- package/dist/server/isr-cache.js.map +1 -1
- package/dist/server/metadata-routes.d.ts +85 -88
- package/dist/server/metadata-routes.js +270 -317
- package/dist/server/metadata-routes.js.map +1 -1
- package/dist/server/middleware-codegen.d.ts +7 -4
- package/dist/server/middleware-codegen.js +61 -61
- package/dist/server/middleware-codegen.js.map +1 -1
- package/dist/server/middleware-request-headers.d.ts +8 -6
- package/dist/server/middleware-request-headers.js +47 -65
- package/dist/server/middleware-request-headers.js.map +1 -1
- package/dist/server/middleware.d.ts +31 -47
- package/dist/server/middleware.js +273 -404
- package/dist/server/middleware.js.map +1 -1
- package/dist/server/normalize-path.d.ts +4 -1
- package/dist/server/normalize-path.js +33 -47
- package/dist/server/normalize-path.js.map +1 -1
- package/dist/server/pages-i18n.d.ts +38 -30
- package/dist/server/pages-i18n.js +112 -139
- package/dist/server/pages-i18n.js.map +1 -1
- package/dist/server/prod-server.d.ts +19 -31
- package/dist/server/prod-server.js +714 -945
- package/dist/server/prod-server.js.map +1 -1
- package/dist/server/request-log.d.ts +18 -12
- package/dist/server/request-log.js +45 -52
- package/dist/server/request-log.js.map +1 -1
- package/dist/server/request-pipeline.d.ts +9 -17
- package/dist/server/request-pipeline.js +133 -184
- package/dist/server/request-pipeline.js.map +1 -1
- package/dist/server/worker-utils.d.ts +4 -1
- package/dist/server/worker-utils.js +31 -37
- package/dist/server/worker-utils.js.map +1 -1
- package/dist/shims/amp.d.ts +5 -2
- package/dist/shims/amp.js +19 -15
- package/dist/shims/amp.js.map +1 -1
- package/dist/shims/app.d.ts +8 -10
- package/dist/shims/app.js +0 -1
- package/dist/shims/cache-runtime.d.ts +20 -45
- package/dist/shims/cache-runtime.js +271 -422
- package/dist/shims/cache-runtime.js.map +1 -1
- package/dist/shims/cache.d.ts +130 -121
- package/dist/shims/cache.js +339 -427
- package/dist/shims/cache.js.map +1 -1
- package/dist/shims/client-only.d.ts +1 -18
- package/dist/shims/client-only.js +0 -17
- package/dist/shims/compat-router.d.ts +4 -1
- package/dist/shims/compat-router.js +23 -19
- package/dist/shims/compat-router.js.map +1 -1
- package/dist/shims/config.d.ts +7 -5
- package/dist/shims/config.js +16 -23
- package/dist/shims/config.js.map +1 -1
- package/dist/shims/constants.d.ts +119 -118
- package/dist/shims/constants.js +159 -164
- package/dist/shims/constants.js.map +1 -1
- package/dist/shims/document.d.ts +20 -16
- package/dist/shims/document.js +41 -22
- package/dist/shims/document.js.map +1 -1
- package/dist/shims/dynamic.d.ts +13 -22
- package/dist/shims/dynamic.js +122 -136
- package/dist/shims/dynamic.js.map +1 -1
- package/dist/shims/error-boundary.d.ts +22 -15
- package/dist/shims/error-boundary.js +81 -79
- package/dist/shims/error-boundary.js.map +1 -1
- package/dist/shims/error.d.ts +11 -12
- package/dist/shims/error.js +35 -39
- package/dist/shims/error.js.map +1 -1
- package/dist/shims/fetch-cache.d.ts +16 -14
- package/dist/shims/fetch-cache.js +437 -645
- package/dist/shims/fetch-cache.js.map +1 -1
- package/dist/shims/font-google-base.d.ts +28 -26
- package/dist/shims/font-google-base.js +238 -325
- package/dist/shims/font-google-base.js.map +1 -1
- package/dist/shims/font-google.d.ts +3 -3
- package/dist/shims/font-google.generated.d.ts +1928 -1924
- package/dist/shims/font-google.generated.js +1928 -2133
- package/dist/shims/font-google.generated.js.map +1 -1
- package/dist/shims/font-google.js +3 -3
- package/dist/shims/font-local.d.ts +28 -26
- package/dist/shims/font-local.js +204 -260
- package/dist/shims/font-local.js.map +1 -1
- package/dist/shims/form.d.ts +13 -27
- package/dist/shims/form.js +128 -180
- package/dist/shims/form.js.map +1 -1
- package/dist/shims/head-state.d.ts +8 -13
- package/dist/shims/head-state.js +25 -42
- package/dist/shims/head-state.js.map +1 -1
- package/dist/shims/head.d.ts +16 -20
- package/dist/shims/head.js +172 -250
- package/dist/shims/head.js.map +1 -1
- package/dist/shims/headers.d.ts +84 -78
- package/dist/shims/headers.js +447 -575
- package/dist/shims/headers.js.map +1 -1
- package/dist/shims/i18n-context.d.ts +16 -20
- package/dist/shims/i18n-context.js +35 -48
- package/dist/shims/i18n-context.js.map +1 -1
- package/dist/shims/i18n-state.d.ts +8 -14
- package/dist/shims/i18n-state.js +34 -42
- package/dist/shims/i18n-state.js.map +1 -1
- package/dist/shims/image-config.d.ts +11 -8
- package/dist/shims/image-config.js +50 -83
- package/dist/shims/image-config.js.map +1 -1
- package/dist/shims/image.d.ts +37 -46
- package/dist/shims/image.js +283 -308
- package/dist/shims/image.js.map +1 -1
- package/dist/shims/internal/api-utils.d.ts +7 -4
- package/dist/shims/internal/api-utils.js +0 -6
- package/dist/shims/internal/app-router-context.d.ts +22 -17
- package/dist/shims/internal/app-router-context.js +17 -13
- package/dist/shims/internal/app-router-context.js.map +1 -1
- package/dist/shims/internal/cookies.d.ts +2 -9
- package/dist/shims/internal/cookies.js +2 -9
- package/dist/shims/internal/parse-cookie-header.d.ts +4 -1
- package/dist/shims/internal/parse-cookie-header.js +29 -29
- package/dist/shims/internal/parse-cookie-header.js.map +1 -1
- package/dist/shims/internal/router-context.d.ts +6 -1
- package/dist/shims/internal/router-context.js +11 -7
- package/dist/shims/internal/router-context.js.map +1 -1
- package/dist/shims/internal/utils.d.ts +40 -37
- package/dist/shims/internal/utils.js +24 -30
- package/dist/shims/internal/utils.js.map +1 -1
- package/dist/shims/internal/work-unit-async-storage.d.ts +6 -10
- package/dist/shims/internal/work-unit-async-storage.js +14 -11
- package/dist/shims/internal/work-unit-async-storage.js.map +1 -1
- package/dist/shims/layout-segment-context.d.ts +11 -14
- package/dist/shims/layout-segment-context.js +24 -23
- package/dist/shims/layout-segment-context.js.map +1 -1
- package/dist/shims/legacy-image.d.ts +39 -46
- package/dist/shims/legacy-image.js +47 -42
- package/dist/shims/legacy-image.js.map +1 -1
- package/dist/shims/link.d.ts +32 -36
- package/dist/shims/link.js +255 -391
- package/dist/shims/link.js.map +1 -1
- package/dist/shims/metadata.d.ts +210 -202
- package/dist/shims/metadata.js +545 -546
- package/dist/shims/metadata.js.map +1 -1
- package/dist/shims/navigation-state.d.ts +10 -18
- package/dist/shims/navigation-state.js +66 -74
- package/dist/shims/navigation-state.js.map +1 -1
- package/dist/shims/navigation.d.ts +59 -63
- package/dist/shims/navigation.js +505 -704
- package/dist/shims/navigation.js.map +1 -1
- package/dist/shims/og.d.ts +2 -20
- package/dist/shims/og.js +2 -19
- package/dist/shims/readonly-url-search-params.d.ts +8 -5
- package/dist/shims/readonly-url-search-params.js +26 -22
- package/dist/shims/readonly-url-search-params.js.map +1 -1
- package/dist/shims/request-context.d.ts +8 -5
- package/dist/shims/request-context.js +50 -60
- package/dist/shims/request-context.js.map +1 -1
- package/dist/shims/request-state-types.d.ts +11 -11
- package/dist/shims/request-state-types.js +0 -1
- package/dist/shims/router-state.d.ts +13 -10
- package/dist/shims/router-state.js +34 -43
- package/dist/shims/router-state.js.map +1 -1
- package/dist/shims/router.d.ts +81 -85
- package/dist/shims/router.js +506 -628
- package/dist/shims/router.js.map +1 -1
- package/dist/shims/script.d.ts +39 -48
- package/dist/shims/script.js +107 -160
- package/dist/shims/script.js.map +1 -1
- package/dist/shims/server-only.d.ts +1 -19
- package/dist/shims/server-only.js +0 -18
- package/dist/shims/server.d.ts +175 -164
- package/dist/shims/server.js +462 -478
- package/dist/shims/server.js.map +1 -1
- package/dist/shims/unified-request-context.d.ts +20 -20
- package/dist/shims/unified-request-context.js +81 -99
- package/dist/shims/unified-request-context.js.map +1 -1
- package/dist/shims/url-safety.d.ts +4 -1
- package/dist/shims/url-safety.js +15 -11
- package/dist/shims/url-safety.js.map +1 -1
- package/dist/shims/url-utils.d.ts +8 -5
- package/dist/shims/url-utils.js +62 -93
- package/dist/shims/url-utils.js.map +1 -1
- package/dist/shims/web-vitals.d.ts +10 -8
- package/dist/shims/web-vitals.js +9 -15
- package/dist/shims/web-vitals.js.map +1 -1
- package/dist/utils/base-path.d.ts +5 -2
- package/dist/utils/base-path.js +21 -19
- package/dist/utils/base-path.js.map +1 -1
- package/dist/utils/domain-locale.d.ts +17 -9
- package/dist/utils/domain-locale.js +36 -56
- package/dist/utils/domain-locale.js.map +1 -1
- package/dist/utils/hash.d.ts +4 -1
- package/dist/utils/hash.js +19 -17
- package/dist/utils/hash.js.map +1 -1
- package/dist/utils/manifest-paths.d.ts +6 -3
- package/dist/utils/manifest-paths.js +15 -16
- package/dist/utils/manifest-paths.js.map +1 -1
- package/dist/utils/project.d.ts +13 -11
- package/dist/utils/project.js +169 -216
- package/dist/utils/project.js.map +1 -1
- package/dist/utils/query.d.ts +8 -6
- package/dist/utils/query.js +57 -67
- package/dist/utils/query.js.map +1 -1
- package/package.json +10 -9
- package/dist/build/report.d.ts.map +0 -1
- package/dist/build/static-export.d.ts.map +0 -1
- package/dist/check.d.ts.map +0 -1
- package/dist/cli.d.ts.map +0 -1
- package/dist/client/entry.d.ts.map +0 -1
- package/dist/client/validate-module-path.d.ts.map +0 -1
- package/dist/client/vinext-next-data.d.ts.map +0 -1
- package/dist/client/vinext-next-data.js.map +0 -1
- package/dist/cloudflare/index.d.ts.map +0 -1
- package/dist/cloudflare/index.js.map +0 -1
- package/dist/cloudflare/kv-cache-handler.d.ts.map +0 -1
- package/dist/cloudflare/tpr.d.ts.map +0 -1
- package/dist/config/config-matchers.d.ts.map +0 -1
- package/dist/config/dotenv.d.ts.map +0 -1
- package/dist/config/next-config.d.ts.map +0 -1
- package/dist/deploy.d.ts.map +0 -1
- package/dist/entries/app-browser-entry.d.ts.map +0 -1
- package/dist/entries/app-rsc-entry.d.ts.map +0 -1
- package/dist/entries/app-ssr-entry.d.ts.map +0 -1
- package/dist/entries/pages-client-entry.d.ts.map +0 -1
- package/dist/entries/pages-entry-helpers.d.ts.map +0 -1
- package/dist/entries/pages-server-entry.d.ts.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/init.d.ts.map +0 -1
- package/dist/plugins/async-hooks-stub.d.ts.map +0 -1
- package/dist/plugins/client-reference-dedup.d.ts.map +0 -1
- package/dist/routing/app-router.d.ts.map +0 -1
- package/dist/routing/file-matcher.d.ts.map +0 -1
- package/dist/routing/pages-router.d.ts.map +0 -1
- package/dist/routing/route-trie.d.ts.map +0 -1
- package/dist/routing/route-validation.d.ts.map +0 -1
- package/dist/routing/utils.d.ts.map +0 -1
- package/dist/server/api-handler.d.ts.map +0 -1
- package/dist/server/app-router-entry.d.ts.map +0 -1
- package/dist/server/dev-module-runner.d.ts.map +0 -1
- package/dist/server/dev-origin-check.d.ts.map +0 -1
- package/dist/server/dev-server.d.ts.map +0 -1
- package/dist/server/html.d.ts.map +0 -1
- package/dist/server/image-optimization.d.ts.map +0 -1
- package/dist/server/instrumentation.d.ts.map +0 -1
- package/dist/server/isr-cache.d.ts.map +0 -1
- package/dist/server/metadata-routes.d.ts.map +0 -1
- package/dist/server/middleware-codegen.d.ts.map +0 -1
- package/dist/server/middleware-request-headers.d.ts.map +0 -1
- package/dist/server/middleware.d.ts.map +0 -1
- package/dist/server/normalize-path.d.ts.map +0 -1
- package/dist/server/pages-i18n.d.ts.map +0 -1
- package/dist/server/prod-server.d.ts.map +0 -1
- package/dist/server/request-log.d.ts.map +0 -1
- package/dist/server/request-pipeline.d.ts.map +0 -1
- package/dist/server/worker-utils.d.ts.map +0 -1
- package/dist/shims/amp.d.ts.map +0 -1
- package/dist/shims/app.d.ts.map +0 -1
- package/dist/shims/app.js.map +0 -1
- package/dist/shims/cache-runtime.d.ts.map +0 -1
- package/dist/shims/cache.d.ts.map +0 -1
- package/dist/shims/client-only.d.ts.map +0 -1
- package/dist/shims/client-only.js.map +0 -1
- package/dist/shims/compat-router.d.ts.map +0 -1
- package/dist/shims/config.d.ts.map +0 -1
- package/dist/shims/constants.d.ts.map +0 -1
- package/dist/shims/document.d.ts.map +0 -1
- package/dist/shims/dynamic.d.ts.map +0 -1
- package/dist/shims/error-boundary.d.ts.map +0 -1
- package/dist/shims/error.d.ts.map +0 -1
- package/dist/shims/fetch-cache.d.ts.map +0 -1
- package/dist/shims/font-google-base.d.ts.map +0 -1
- package/dist/shims/font-google.d.ts.map +0 -1
- package/dist/shims/font-google.generated.d.ts.map +0 -1
- package/dist/shims/font-google.js.map +0 -1
- package/dist/shims/font-local.d.ts.map +0 -1
- package/dist/shims/form.d.ts.map +0 -1
- package/dist/shims/head-state.d.ts.map +0 -1
- package/dist/shims/head.d.ts.map +0 -1
- package/dist/shims/headers.d.ts.map +0 -1
- package/dist/shims/i18n-context.d.ts.map +0 -1
- package/dist/shims/i18n-state.d.ts.map +0 -1
- package/dist/shims/image-config.d.ts.map +0 -1
- package/dist/shims/image.d.ts.map +0 -1
- package/dist/shims/internal/api-utils.d.ts.map +0 -1
- package/dist/shims/internal/api-utils.js.map +0 -1
- package/dist/shims/internal/app-router-context.d.ts.map +0 -1
- package/dist/shims/internal/cookies.d.ts.map +0 -1
- package/dist/shims/internal/cookies.js.map +0 -1
- package/dist/shims/internal/parse-cookie-header.d.ts.map +0 -1
- package/dist/shims/internal/router-context.d.ts.map +0 -1
- package/dist/shims/internal/utils.d.ts.map +0 -1
- package/dist/shims/internal/work-unit-async-storage.d.ts.map +0 -1
- package/dist/shims/layout-segment-context.d.ts.map +0 -1
- package/dist/shims/legacy-image.d.ts.map +0 -1
- package/dist/shims/link.d.ts.map +0 -1
- package/dist/shims/metadata.d.ts.map +0 -1
- package/dist/shims/navigation-state.d.ts.map +0 -1
- package/dist/shims/navigation.d.ts.map +0 -1
- package/dist/shims/og.d.ts.map +0 -1
- package/dist/shims/og.js.map +0 -1
- package/dist/shims/readonly-url-search-params.d.ts.map +0 -1
- package/dist/shims/request-context.d.ts.map +0 -1
- package/dist/shims/request-state-types.d.ts.map +0 -1
- package/dist/shims/request-state-types.js.map +0 -1
- package/dist/shims/router-state.d.ts.map +0 -1
- package/dist/shims/router.d.ts.map +0 -1
- package/dist/shims/script.d.ts.map +0 -1
- package/dist/shims/server-only.d.ts.map +0 -1
- package/dist/shims/server-only.js.map +0 -1
- package/dist/shims/server.d.ts.map +0 -1
- package/dist/shims/unified-request-context.d.ts.map +0 -1
- package/dist/shims/url-safety.d.ts.map +0 -1
- package/dist/shims/url-utils.d.ts.map +0 -1
- package/dist/shims/web-vitals.d.ts.map +0 -1
- package/dist/utils/base-path.d.ts.map +0 -1
- package/dist/utils/domain-locale.d.ts.map +0 -1
- package/dist/utils/hash.d.ts.map +0 -1
- package/dist/utils/manifest-paths.d.ts.map +0 -1
- package/dist/utils/project.d.ts.map +0 -1
- package/dist/utils/query.d.ts.map +0 -1
|
@@ -1,468 +1,317 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
*
|
|
4
|
-
* This module provides the runtime for "use cache" directive support.
|
|
5
|
-
* Functions marked with "use cache" are transformed by the vinext:use-cache
|
|
6
|
-
* Vite plugin to wrap them with `registerCachedFunction()`.
|
|
7
|
-
*
|
|
8
|
-
* The runtime:
|
|
9
|
-
* 1. Generates a cache key from function identity + serialized arguments
|
|
10
|
-
* 2. Checks the CacheHandler for a cached value
|
|
11
|
-
* 3. On HIT: returns the cached value (deserialized via RSC stream)
|
|
12
|
-
* 4. On MISS: creates an AsyncLocalStorage context for cacheLife/cacheTag,
|
|
13
|
-
* calls the original function, serializes the result via RSC stream,
|
|
14
|
-
* collects metadata, stores the result
|
|
15
|
-
*
|
|
16
|
-
* Serialization uses the RSC protocol (renderToReadableStream /
|
|
17
|
-
* createFromReadableStream / encodeReply) from @vitejs/plugin-rsc.
|
|
18
|
-
* This correctly handles React elements, client references, Promises,
|
|
19
|
-
* and all RSC-serializable types — unlike JSON.stringify which silently
|
|
20
|
-
* drops $$typeof Symbols and function values.
|
|
21
|
-
*
|
|
22
|
-
* When RSC APIs are unavailable (e.g. in unit tests), falls back to
|
|
23
|
-
* JSON.stringify/parse with the same stableStringify cache key generation.
|
|
24
|
-
*
|
|
25
|
-
* Cache variants:
|
|
26
|
-
* - "use cache" — shared cache (default profile)
|
|
27
|
-
* - "use cache: remote" — shared cache (explicit)
|
|
28
|
-
* - "use cache: private" — per-request cache (not shared across requests)
|
|
29
|
-
*/
|
|
1
|
+
import { getRequestContext, isInsideUnifiedScope, runWithUnifiedStateMutation } from "./unified-request-context.js";
|
|
2
|
+
import { _registerCacheContextAccessor, cacheLifeProfiles, getCacheHandler } from "./cache.js";
|
|
30
3
|
import { AsyncLocalStorage } from "node:async_hooks";
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
4
|
+
//#region src/shims/cache-runtime.ts
|
|
5
|
+
/**
|
|
6
|
+
* "use cache" runtime
|
|
7
|
+
*
|
|
8
|
+
* This module provides the runtime for "use cache" directive support.
|
|
9
|
+
* Functions marked with "use cache" are transformed by the vinext:use-cache
|
|
10
|
+
* Vite plugin to wrap them with `registerCachedFunction()`.
|
|
11
|
+
*
|
|
12
|
+
* The runtime:
|
|
13
|
+
* 1. Generates a cache key from function identity + serialized arguments
|
|
14
|
+
* 2. Checks the CacheHandler for a cached value
|
|
15
|
+
* 3. On HIT: returns the cached value (deserialized via RSC stream)
|
|
16
|
+
* 4. On MISS: creates an AsyncLocalStorage context for cacheLife/cacheTag,
|
|
17
|
+
* calls the original function, serializes the result via RSC stream,
|
|
18
|
+
* collects metadata, stores the result
|
|
19
|
+
*
|
|
20
|
+
* Serialization uses the RSC protocol (renderToReadableStream /
|
|
21
|
+
* createFromReadableStream / encodeReply) from @vitejs/plugin-rsc.
|
|
22
|
+
* This correctly handles React elements, client references, Promises,
|
|
23
|
+
* and all RSC-serializable types — unlike JSON.stringify which silently
|
|
24
|
+
* drops $$typeof Symbols and function values.
|
|
25
|
+
*
|
|
26
|
+
* When RSC APIs are unavailable (e.g. in unit tests), falls back to
|
|
27
|
+
* JSON.stringify/parse with the same stableStringify cache key generation.
|
|
28
|
+
*
|
|
29
|
+
* Cache variants:
|
|
30
|
+
* - "use cache" — shared cache (default profile)
|
|
31
|
+
* - "use cache: remote" — shared cache (explicit)
|
|
32
|
+
* - "use cache: private" — per-request cache (not shared across requests)
|
|
33
|
+
*/
|
|
35
34
|
const _CONTEXT_ALS_KEY = Symbol.for("vinext.cacheRuntime.contextAls");
|
|
36
35
|
const _gCacheRuntime = globalThis;
|
|
37
|
-
|
|
38
|
-
new AsyncLocalStorage());
|
|
39
|
-
// Register the context accessor so cacheLife()/cacheTag() in cache.ts can
|
|
40
|
-
// access the context without a circular import.
|
|
36
|
+
const cacheContextStorage = _gCacheRuntime[_CONTEXT_ALS_KEY] ??= new AsyncLocalStorage();
|
|
41
37
|
_registerCacheContextAccessor(() => cacheContextStorage.getStore() ?? null);
|
|
42
38
|
/**
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
39
|
+
* Get the current cache context. Returns null if not inside a "use cache" function.
|
|
40
|
+
*/
|
|
41
|
+
function getCacheContext() {
|
|
42
|
+
return cacheContextStorage.getStore() ?? null;
|
|
47
43
|
}
|
|
48
44
|
const NOT_LOADED = Symbol("not-loaded");
|
|
49
45
|
let _rscModule = NOT_LOADED;
|
|
50
46
|
async function getRscModule() {
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
}
|
|
59
|
-
return _rscModule;
|
|
47
|
+
if (_rscModule !== NOT_LOADED) return _rscModule;
|
|
48
|
+
try {
|
|
49
|
+
_rscModule = await import("@vitejs/plugin-rsc/react/rsc");
|
|
50
|
+
} catch {
|
|
51
|
+
_rscModule = null;
|
|
52
|
+
}
|
|
53
|
+
return _rscModule;
|
|
60
54
|
}
|
|
61
|
-
// ---------------------------------------------------------------------------
|
|
62
|
-
// RSC stream helpers
|
|
63
|
-
// ---------------------------------------------------------------------------
|
|
64
55
|
/** Collect a ReadableStream<Uint8Array> into a single Uint8Array. */
|
|
65
56
|
async function collectStream(stream) {
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
}
|
|
84
|
-
return result;
|
|
57
|
+
const reader = stream.getReader();
|
|
58
|
+
const chunks = [];
|
|
59
|
+
let totalLength = 0;
|
|
60
|
+
for (;;) {
|
|
61
|
+
const { done, value } = await reader.read();
|
|
62
|
+
if (done) break;
|
|
63
|
+
chunks.push(value);
|
|
64
|
+
totalLength += value.length;
|
|
65
|
+
}
|
|
66
|
+
if (chunks.length === 1) return chunks[0];
|
|
67
|
+
const result = new Uint8Array(totalLength);
|
|
68
|
+
let offset = 0;
|
|
69
|
+
for (const chunk of chunks) {
|
|
70
|
+
result.set(chunk, offset);
|
|
71
|
+
offset += chunk.length;
|
|
72
|
+
}
|
|
73
|
+
return result;
|
|
85
74
|
}
|
|
86
75
|
/** Encode a Uint8Array as a base64 string for storage. Uses Node Buffer. */
|
|
87
76
|
function uint8ToBase64(bytes) {
|
|
88
|
-
|
|
77
|
+
return Buffer.from(bytes).toString("base64");
|
|
89
78
|
}
|
|
90
79
|
/** Decode a base64 string back to Uint8Array. Uses Node Buffer. */
|
|
91
80
|
function base64ToUint8(base64) {
|
|
92
|
-
|
|
81
|
+
return new Uint8Array(Buffer.from(base64, "base64"));
|
|
93
82
|
}
|
|
94
83
|
/** Create a ReadableStream from a Uint8Array. */
|
|
95
84
|
function uint8ToStream(bytes) {
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
},
|
|
101
|
-
});
|
|
85
|
+
return new ReadableStream({ start(controller) {
|
|
86
|
+
controller.enqueue(bytes);
|
|
87
|
+
controller.close();
|
|
88
|
+
} });
|
|
102
89
|
}
|
|
103
90
|
/**
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
// Blob/File: include type, size, and content bytes
|
|
126
|
-
const bytes = new Uint8Array(await value.arrayBuffer());
|
|
127
|
-
parts.push(`${name}=b:${value.type}:${value.size}:${Buffer.from(bytes).toString("base64")}`);
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
const payload = new TextEncoder().encode(parts.join("\0"));
|
|
131
|
-
const hashBuffer = await crypto.subtle.digest("SHA-256", payload);
|
|
132
|
-
return Buffer.from(new Uint8Array(hashBuffer)).toString("base64url");
|
|
91
|
+
* Convert an encodeReply result (string | FormData) to a cache key string.
|
|
92
|
+
* For FormData (binary args), produces a deterministic SHA-256 hash over
|
|
93
|
+
* the sorted entries. We can't hash `new Response(formData).arrayBuffer()`
|
|
94
|
+
* because multipart boundaries are non-deterministic across serializations.
|
|
95
|
+
*
|
|
96
|
+
* Exported for testing.
|
|
97
|
+
*/
|
|
98
|
+
async function replyToCacheKey(reply) {
|
|
99
|
+
if (typeof reply === "string") return reply;
|
|
100
|
+
const entries = [...reply.entries()];
|
|
101
|
+
const valStr = (v) => typeof v === "string" ? v : v.name;
|
|
102
|
+
entries.sort((a, b) => a[0].localeCompare(b[0]) || valStr(a[1]).localeCompare(valStr(b[1])));
|
|
103
|
+
const parts = [];
|
|
104
|
+
for (const [name, value] of entries) if (typeof value === "string") parts.push(`${name}=s:${value}`);
|
|
105
|
+
else {
|
|
106
|
+
const bytes = new Uint8Array(await value.arrayBuffer());
|
|
107
|
+
parts.push(`${name}=b:${value.type}:${value.size}:${Buffer.from(bytes).toString("base64")}`);
|
|
108
|
+
}
|
|
109
|
+
const payload = new TextEncoder().encode(parts.join("\0"));
|
|
110
|
+
const hashBuffer = await crypto.subtle.digest("SHA-256", payload);
|
|
111
|
+
return Buffer.from(new Uint8Array(hashBuffer)).toString("base64url");
|
|
133
112
|
}
|
|
134
|
-
// ---------------------------------------------------------------------------
|
|
135
|
-
// Minimum-wins resolution for cacheLife
|
|
136
|
-
// ---------------------------------------------------------------------------
|
|
137
113
|
/**
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
114
|
+
* Resolve collected cacheLife configs into a single effective config.
|
|
115
|
+
* The "minimum-wins" rule: if multiple cacheLife() calls are made,
|
|
116
|
+
* each field takes the smallest value across all calls.
|
|
117
|
+
*/
|
|
142
118
|
function resolveCacheLife(configs) {
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
for (const config of configs) {
|
|
153
|
-
if (config.stale !== undefined) {
|
|
154
|
-
result.stale =
|
|
155
|
-
result.stale !== undefined ? Math.min(result.stale, config.stale) : config.stale;
|
|
156
|
-
}
|
|
157
|
-
if (config.revalidate !== undefined) {
|
|
158
|
-
result.revalidate =
|
|
159
|
-
result.revalidate !== undefined
|
|
160
|
-
? Math.min(result.revalidate, config.revalidate)
|
|
161
|
-
: config.revalidate;
|
|
162
|
-
}
|
|
163
|
-
if (config.expire !== undefined) {
|
|
164
|
-
result.expire =
|
|
165
|
-
result.expire !== undefined ? Math.min(result.expire, config.expire) : config.expire;
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
return result;
|
|
119
|
+
if (configs.length === 0) return { ...cacheLifeProfiles.default };
|
|
120
|
+
if (configs.length === 1) return { ...configs[0] };
|
|
121
|
+
const result = {};
|
|
122
|
+
for (const config of configs) {
|
|
123
|
+
if (config.stale !== void 0) result.stale = result.stale !== void 0 ? Math.min(result.stale, config.stale) : config.stale;
|
|
124
|
+
if (config.revalidate !== void 0) result.revalidate = result.revalidate !== void 0 ? Math.min(result.revalidate, config.revalidate) : config.revalidate;
|
|
125
|
+
if (config.expire !== void 0) result.expire = result.expire !== void 0 ? Math.min(result.expire, config.expire) : config.expire;
|
|
126
|
+
}
|
|
127
|
+
return result;
|
|
169
128
|
}
|
|
170
129
|
const _PRIVATE_ALS_KEY = Symbol.for("vinext.cacheRuntime.privateAls");
|
|
171
130
|
const _PRIVATE_FALLBACK_KEY = Symbol.for("vinext.cacheRuntime.privateFallback");
|
|
172
131
|
const _g = globalThis;
|
|
173
|
-
const _privateAls =
|
|
174
|
-
|
|
175
|
-
const _privateFallbackState = (_g[_PRIVATE_FALLBACK_KEY] ??= {
|
|
176
|
-
_privateCache: new Map(),
|
|
177
|
-
});
|
|
132
|
+
const _privateAls = _g[_PRIVATE_ALS_KEY] ??= new AsyncLocalStorage();
|
|
133
|
+
const _privateFallbackState = _g[_PRIVATE_FALLBACK_KEY] ??= { _privateCache: /* @__PURE__ */ new Map() };
|
|
178
134
|
function _getPrivateState() {
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
}
|
|
186
|
-
return _privateAls.getStore() ?? _privateFallbackState;
|
|
135
|
+
if (isInsideUnifiedScope()) {
|
|
136
|
+
const ctx = getRequestContext();
|
|
137
|
+
if (ctx._privateCache === null) ctx._privateCache = /* @__PURE__ */ new Map();
|
|
138
|
+
return ctx;
|
|
139
|
+
}
|
|
140
|
+
return _privateAls.getStore() ?? _privateFallbackState;
|
|
187
141
|
}
|
|
188
142
|
/**
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
const state = {
|
|
200
|
-
_privateCache: new Map(),
|
|
201
|
-
};
|
|
202
|
-
return _privateAls.run(state, fn);
|
|
143
|
+
* Run a function within a private cache ALS scope.
|
|
144
|
+
* Ensures per-request isolation for "use cache: private" entries
|
|
145
|
+
* on concurrent runtimes.
|
|
146
|
+
*/
|
|
147
|
+
function runWithPrivateCache(fn) {
|
|
148
|
+
if (isInsideUnifiedScope()) return runWithUnifiedStateMutation((uCtx) => {
|
|
149
|
+
uCtx._privateCache = /* @__PURE__ */ new Map();
|
|
150
|
+
}, fn);
|
|
151
|
+
const state = { _privateCache: /* @__PURE__ */ new Map() };
|
|
152
|
+
return _privateAls.run(state, fn);
|
|
203
153
|
}
|
|
204
154
|
/**
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
}
|
|
217
|
-
else {
|
|
218
|
-
_privateFallbackState._privateCache = new Map();
|
|
219
|
-
}
|
|
155
|
+
* Clear the private per-request cache. Should be called at the start of each request.
|
|
156
|
+
* Only needed when not using runWithPrivateCache() (legacy path).
|
|
157
|
+
*/
|
|
158
|
+
function clearPrivateCache() {
|
|
159
|
+
if (isInsideUnifiedScope()) {
|
|
160
|
+
getRequestContext()._privateCache = /* @__PURE__ */ new Map();
|
|
161
|
+
return;
|
|
162
|
+
}
|
|
163
|
+
const state = _privateAls.getStore();
|
|
164
|
+
if (state) state._privateCache = /* @__PURE__ */ new Map();
|
|
165
|
+
else _privateFallbackState._privateCache = /* @__PURE__ */ new Map();
|
|
220
166
|
}
|
|
221
|
-
// ---------------------------------------------------------------------------
|
|
222
|
-
// Core runtime: registerCachedFunction
|
|
223
|
-
// ---------------------------------------------------------------------------
|
|
224
167
|
/**
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
return JSON.parse(existing.value.data.body);
|
|
307
|
-
}
|
|
308
|
-
catch {
|
|
309
|
-
// Corrupted entry, fall through to re-execute
|
|
310
|
-
}
|
|
311
|
-
}
|
|
312
|
-
// Cache miss (or stale) — execute with context
|
|
313
|
-
const ctx = {
|
|
314
|
-
tags: [],
|
|
315
|
-
lifeConfigs: [],
|
|
316
|
-
variant: cacheVariant || "default",
|
|
317
|
-
};
|
|
318
|
-
const result = await cacheContextStorage.run(ctx, () => fn(...args));
|
|
319
|
-
// Resolve effective cache life from collected configs
|
|
320
|
-
const effectiveLife = resolveCacheLife(ctx.lifeConfigs);
|
|
321
|
-
const revalidateSeconds = effectiveLife.revalidate ?? cacheLifeProfiles.default.revalidate ?? 900;
|
|
322
|
-
// Store in cache — use RSC stream serialization when available (handles
|
|
323
|
-
// React elements, client refs, Promises, etc.), JSON otherwise.
|
|
324
|
-
try {
|
|
325
|
-
let body;
|
|
326
|
-
const headers = {};
|
|
327
|
-
if (rsc) {
|
|
328
|
-
// RSC serialization: result → stream → bytes → base64.
|
|
329
|
-
// No temporaryReferences — cached values must be self-contained
|
|
330
|
-
// since they're persisted across requests.
|
|
331
|
-
const stream = rsc.renderToReadableStream(result);
|
|
332
|
-
const bytes = await collectStream(stream);
|
|
333
|
-
body = uint8ToBase64(bytes);
|
|
334
|
-
headers["x-vinext-rsc"] = "1";
|
|
335
|
-
}
|
|
336
|
-
else {
|
|
337
|
-
// JSON fallback
|
|
338
|
-
body = JSON.stringify(result);
|
|
339
|
-
if (body === undefined)
|
|
340
|
-
return result;
|
|
341
|
-
}
|
|
342
|
-
const cacheValue = {
|
|
343
|
-
kind: "FETCH",
|
|
344
|
-
data: {
|
|
345
|
-
headers,
|
|
346
|
-
body,
|
|
347
|
-
url: cacheKey,
|
|
348
|
-
},
|
|
349
|
-
tags: ctx.tags,
|
|
350
|
-
revalidate: revalidateSeconds,
|
|
351
|
-
};
|
|
352
|
-
await handler.set(cacheKey, cacheValue, {
|
|
353
|
-
fetchCache: true,
|
|
354
|
-
tags: ctx.tags,
|
|
355
|
-
revalidate: revalidateSeconds,
|
|
356
|
-
});
|
|
357
|
-
}
|
|
358
|
-
catch {
|
|
359
|
-
// Result not serializable — skip caching, still return the result
|
|
360
|
-
}
|
|
361
|
-
return result;
|
|
362
|
-
};
|
|
363
|
-
return cachedFn;
|
|
168
|
+
* Register a function as a cached function. This is called by the Vite
|
|
169
|
+
* transform for each "use cache" function.
|
|
170
|
+
*
|
|
171
|
+
* @param fn - The original async function
|
|
172
|
+
* @param id - A stable identifier for the function (module path + export name)
|
|
173
|
+
* @param variant - Cache variant: "" (default/shared), "remote", "private"
|
|
174
|
+
* @returns A wrapper function that checks cache before calling the original
|
|
175
|
+
*/
|
|
176
|
+
function registerCachedFunction(fn, id, variant) {
|
|
177
|
+
const cacheVariant = variant ?? "";
|
|
178
|
+
const isDev = typeof process !== "undefined" && process.env.NODE_ENV === "development";
|
|
179
|
+
const cachedFn = async (...args) => {
|
|
180
|
+
const rsc = await getRscModule();
|
|
181
|
+
let cacheKey;
|
|
182
|
+
try {
|
|
183
|
+
if (rsc && args.length > 0) {
|
|
184
|
+
const tempRefs = rsc.createClientTemporaryReferenceSet();
|
|
185
|
+
const processedArgs = unwrapThenableObjects(args);
|
|
186
|
+
cacheKey = `use-cache:${id}:${await replyToCacheKey(await rsc.encodeReply(processedArgs, { temporaryReferences: tempRefs }))}`;
|
|
187
|
+
} else cacheKey = `use-cache:${id}${args.length > 0 ? ":" + stableStringify(args) : ""}`;
|
|
188
|
+
} catch {
|
|
189
|
+
return fn(...args);
|
|
190
|
+
}
|
|
191
|
+
if (cacheVariant === "private") {
|
|
192
|
+
const privateCache = _getPrivateState()._privateCache;
|
|
193
|
+
const privateHit = privateCache.get(cacheKey);
|
|
194
|
+
if (privateHit !== void 0) return privateHit;
|
|
195
|
+
const result = await executeWithContext(fn, args, cacheVariant);
|
|
196
|
+
privateCache.set(cacheKey, result);
|
|
197
|
+
return result;
|
|
198
|
+
}
|
|
199
|
+
if (isDev) return cacheContextStorage.run({
|
|
200
|
+
tags: [],
|
|
201
|
+
lifeConfigs: [],
|
|
202
|
+
variant: cacheVariant || "default"
|
|
203
|
+
}, () => fn(...args));
|
|
204
|
+
const handler = getCacheHandler();
|
|
205
|
+
const existing = await handler.get(cacheKey, { kind: "FETCH" });
|
|
206
|
+
if (existing?.value && existing.value.kind === "FETCH" && existing.cacheState !== "stale") try {
|
|
207
|
+
if (rsc && existing.value.data.headers["x-vinext-rsc"] === "1") {
|
|
208
|
+
const stream = uint8ToStream(base64ToUint8(existing.value.data.body));
|
|
209
|
+
return await rsc.createFromReadableStream(stream);
|
|
210
|
+
}
|
|
211
|
+
return JSON.parse(existing.value.data.body);
|
|
212
|
+
} catch {}
|
|
213
|
+
const ctx = {
|
|
214
|
+
tags: [],
|
|
215
|
+
lifeConfigs: [],
|
|
216
|
+
variant: cacheVariant || "default"
|
|
217
|
+
};
|
|
218
|
+
const result = await cacheContextStorage.run(ctx, () => fn(...args));
|
|
219
|
+
const revalidateSeconds = resolveCacheLife(ctx.lifeConfigs).revalidate ?? cacheLifeProfiles.default.revalidate ?? 900;
|
|
220
|
+
try {
|
|
221
|
+
let body;
|
|
222
|
+
const headers = {};
|
|
223
|
+
if (rsc) {
|
|
224
|
+
body = uint8ToBase64(await collectStream(rsc.renderToReadableStream(result)));
|
|
225
|
+
headers["x-vinext-rsc"] = "1";
|
|
226
|
+
} else {
|
|
227
|
+
body = JSON.stringify(result);
|
|
228
|
+
if (body === void 0) return result;
|
|
229
|
+
}
|
|
230
|
+
const cacheValue = {
|
|
231
|
+
kind: "FETCH",
|
|
232
|
+
data: {
|
|
233
|
+
headers,
|
|
234
|
+
body,
|
|
235
|
+
url: cacheKey
|
|
236
|
+
},
|
|
237
|
+
tags: ctx.tags,
|
|
238
|
+
revalidate: revalidateSeconds
|
|
239
|
+
};
|
|
240
|
+
await handler.set(cacheKey, cacheValue, {
|
|
241
|
+
fetchCache: true,
|
|
242
|
+
tags: ctx.tags,
|
|
243
|
+
revalidate: revalidateSeconds
|
|
244
|
+
});
|
|
245
|
+
} catch {}
|
|
246
|
+
return result;
|
|
247
|
+
};
|
|
248
|
+
return cachedFn;
|
|
364
249
|
}
|
|
365
|
-
// ---------------------------------------------------------------------------
|
|
366
|
-
// Helper: execute function within cache context
|
|
367
|
-
// ---------------------------------------------------------------------------
|
|
368
250
|
async function executeWithContext(fn, args, variant) {
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
251
|
+
const ctx = {
|
|
252
|
+
tags: [],
|
|
253
|
+
lifeConfigs: [],
|
|
254
|
+
variant: variant || "default"
|
|
255
|
+
};
|
|
256
|
+
return cacheContextStorage.run(ctx, () => fn(...args));
|
|
375
257
|
}
|
|
376
|
-
// ---------------------------------------------------------------------------
|
|
377
|
-
// Unwrap Promise-augmented objects for cache key generation
|
|
378
|
-
// ---------------------------------------------------------------------------
|
|
379
258
|
/**
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
259
|
+
* Recursively unwrap "thenable objects" — values created by
|
|
260
|
+
* `Object.assign(Promise.resolve(obj), obj)` — into plain objects.
|
|
261
|
+
*
|
|
262
|
+
* Next.js 16 params and searchParams are passed as Promise-augmented objects
|
|
263
|
+
* that work both as `await params` and `params.key`. When these are fed to
|
|
264
|
+
* `encodeReply` with `temporaryReferences`, the Promise is treated as a
|
|
265
|
+
* temporary reference and its actual values are **excluded** from the
|
|
266
|
+
* serialized output. This means different param values (e.g.,
|
|
267
|
+
* `section:"sports"` vs `section:"electronics"`) produce identical cache keys.
|
|
268
|
+
*
|
|
269
|
+
* This function extracts the own enumerable properties into plain objects
|
|
270
|
+
* so `encodeReply` can serialize the actual values into the cache key.
|
|
271
|
+
* Only used for cache key generation — the original Promise-augmented
|
|
272
|
+
* objects are still passed to the actual function on cache miss.
|
|
273
|
+
*/
|
|
395
274
|
function unwrapThenableObjects(value) {
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
}
|
|
411
|
-
return plain;
|
|
412
|
-
}
|
|
413
|
-
// Pure Promise with no own properties — leave as-is
|
|
414
|
-
return value;
|
|
415
|
-
}
|
|
416
|
-
// Regular object — recurse into values
|
|
417
|
-
const result = {};
|
|
418
|
-
for (const key of Object.keys(value)) {
|
|
419
|
-
result[key] = unwrapThenableObjects(value[key]);
|
|
420
|
-
}
|
|
421
|
-
return result;
|
|
275
|
+
if (value === null || value === void 0 || typeof value !== "object") return value;
|
|
276
|
+
if (Array.isArray(value)) return value.map(unwrapThenableObjects);
|
|
277
|
+
if (typeof value.then === "function") {
|
|
278
|
+
const keys = Object.keys(value);
|
|
279
|
+
if (keys.length > 0) {
|
|
280
|
+
const plain = {};
|
|
281
|
+
for (const key of keys) plain[key] = unwrapThenableObjects(value[key]);
|
|
282
|
+
return plain;
|
|
283
|
+
}
|
|
284
|
+
return value;
|
|
285
|
+
}
|
|
286
|
+
const result = {};
|
|
287
|
+
for (const key of Object.keys(value)) result[key] = unwrapThenableObjects(value[key]);
|
|
288
|
+
return result;
|
|
422
289
|
}
|
|
423
|
-
// ---------------------------------------------------------------------------
|
|
424
|
-
// Fallback: stable JSON serialization for cache keys (when RSC unavailable)
|
|
425
|
-
// ---------------------------------------------------------------------------
|
|
426
290
|
function stableStringify(value, seen) {
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
return `Date(${value.getTime()})`;
|
|
450
|
-
}
|
|
451
|
-
// Circular reference detection
|
|
452
|
-
if (!seen)
|
|
453
|
-
seen = new Set();
|
|
454
|
-
if (seen.has(value))
|
|
455
|
-
throw new Error("Circular reference");
|
|
456
|
-
seen.add(value);
|
|
457
|
-
const keys = Object.keys(value).sort();
|
|
458
|
-
const result = "{" +
|
|
459
|
-
keys
|
|
460
|
-
.map((k) => `${JSON.stringify(k)}:${stableStringify(value[k], seen)}`)
|
|
461
|
-
.join(",") +
|
|
462
|
-
"}";
|
|
463
|
-
seen.delete(value);
|
|
464
|
-
return result;
|
|
465
|
-
}
|
|
466
|
-
return JSON.stringify(value);
|
|
291
|
+
if (value === void 0) return "undefined";
|
|
292
|
+
if (value === null) return "null";
|
|
293
|
+
if (typeof value === "function") throw new Error("Cannot serialize function");
|
|
294
|
+
if (typeof value === "symbol") throw new Error("Cannot serialize symbol");
|
|
295
|
+
if (Array.isArray(value)) {
|
|
296
|
+
if (!seen) seen = /* @__PURE__ */ new Set();
|
|
297
|
+
if (seen.has(value)) throw new Error("Circular reference");
|
|
298
|
+
seen.add(value);
|
|
299
|
+
const result = "[" + value.map((v) => stableStringify(v, seen)).join(",") + "]";
|
|
300
|
+
seen.delete(value);
|
|
301
|
+
return result;
|
|
302
|
+
}
|
|
303
|
+
if (typeof value === "object" && value !== null) {
|
|
304
|
+
if (value instanceof Date) return `Date(${value.getTime()})`;
|
|
305
|
+
if (!seen) seen = /* @__PURE__ */ new Set();
|
|
306
|
+
if (seen.has(value)) throw new Error("Circular reference");
|
|
307
|
+
seen.add(value);
|
|
308
|
+
const result = "{" + Object.keys(value).sort().map((k) => `${JSON.stringify(k)}:${stableStringify(value[k], seen)}`).join(",") + "}";
|
|
309
|
+
seen.delete(value);
|
|
310
|
+
return result;
|
|
311
|
+
}
|
|
312
|
+
return JSON.stringify(value);
|
|
467
313
|
}
|
|
314
|
+
//#endregion
|
|
315
|
+
export { cacheContextStorage, clearPrivateCache, getCacheContext, registerCachedFunction, replyToCacheKey, runWithPrivateCache };
|
|
316
|
+
|
|
468
317
|
//# sourceMappingURL=cache-runtime.js.map
|