full site update
This commit is contained in:
112
node_modules/astro/dist/vite-plugin-astro-server/plugin.js
generated
vendored
112
node_modules/astro/dist/vite-plugin-astro-server/plugin.js
generated
vendored
@@ -1,56 +1,89 @@
|
||||
import { AsyncLocalStorage } from "node:async_hooks";
|
||||
import { IncomingMessage } from "node:http";
|
||||
import { createKey } from "../core/encryption.js";
|
||||
import { fileURLToPath } from "node:url";
|
||||
import { normalizePath } from "vite";
|
||||
import {
|
||||
getAlgorithm,
|
||||
getDirectives,
|
||||
getScriptHashes,
|
||||
getScriptResources,
|
||||
getStrictDynamic,
|
||||
getStyleHashes,
|
||||
getStyleResources,
|
||||
shouldTrackCspHashes
|
||||
} from "../core/csp/common.js";
|
||||
import { warnMissingAdapter } from "../core/dev/adapter-validation.js";
|
||||
import { createKey, getEnvironmentKey, hasEnvironmentKey } from "../core/encryption.js";
|
||||
import { getViteErrorPayload } from "../core/errors/dev/index.js";
|
||||
import { AstroError, AstroErrorData } from "../core/errors/index.js";
|
||||
import { patchOverlay } from "../core/errors/overlay.js";
|
||||
import { NOOP_MIDDLEWARE_FN } from "../core/middleware/noop-middleware.js";
|
||||
import { createViteLoader } from "../core/module-loader/index.js";
|
||||
import { injectDefaultRoutes } from "../core/routing/default.js";
|
||||
import { createRouteManifest } from "../core/routing/index.js";
|
||||
import { createRoutesList } from "../core/routing/index.js";
|
||||
import { getRoutePrerenderOption } from "../core/routing/manifest/prerender.js";
|
||||
import { toFallbackType, toRoutingStrategy } from "../i18n/utils.js";
|
||||
import { runHookRoutesResolved } from "../integrations/hooks.js";
|
||||
import { baseMiddleware } from "./base.js";
|
||||
import { createController } from "./controller.js";
|
||||
import { recordServerError } from "./error.js";
|
||||
import { DevPipeline } from "./pipeline.js";
|
||||
import { handleRequest } from "./request.js";
|
||||
import { setRouteError } from "./server-state.js";
|
||||
import { trailingSlashMiddleware } from "./trailing-slash.js";
|
||||
function createVitePluginAstroServer({
|
||||
settings,
|
||||
logger,
|
||||
fs: fsMod
|
||||
fs: fsMod,
|
||||
routesList,
|
||||
manifest
|
||||
}) {
|
||||
return {
|
||||
name: "astro:server",
|
||||
configureServer(viteServer) {
|
||||
async configureServer(viteServer) {
|
||||
const loader = createViteLoader(viteServer);
|
||||
const manifest = createDevelopmentManifest(settings);
|
||||
let manifestData = injectDefaultRoutes(
|
||||
const pipeline = DevPipeline.create(routesList, {
|
||||
loader,
|
||||
logger,
|
||||
manifest,
|
||||
createRouteManifest({ settings, fsMod }, logger)
|
||||
);
|
||||
const pipeline = DevPipeline.create(manifestData, { loader, logger, manifest, settings });
|
||||
settings
|
||||
});
|
||||
const controller = createController({ loader });
|
||||
const localStorage = new AsyncLocalStorage();
|
||||
function rebuildManifest(needsManifestRebuild) {
|
||||
async function rebuildManifest(path = null) {
|
||||
pipeline.clearRouteCache();
|
||||
if (needsManifestRebuild) {
|
||||
manifestData = injectDefaultRoutes(manifest, createRouteManifest({ settings }, logger));
|
||||
pipeline.setManifestData(manifestData);
|
||||
if (path !== null) {
|
||||
const route = routesList.routes.find(
|
||||
(r) => normalizePath(path) === normalizePath(fileURLToPath(new URL(r.component, settings.config.root)))
|
||||
);
|
||||
if (!route) {
|
||||
return;
|
||||
}
|
||||
if (route.type !== "page" && route.type !== "endpoint") return;
|
||||
const routePath = fileURLToPath(new URL(route.component, settings.config.root));
|
||||
try {
|
||||
const content = await fsMod.promises.readFile(routePath, "utf-8");
|
||||
await getRoutePrerenderOption(content, route, settings, logger);
|
||||
await runHookRoutesResolved({ routes: routesList.routes, settings, logger });
|
||||
} catch (_) {
|
||||
}
|
||||
} else {
|
||||
routesList = await createRoutesList({ settings, fsMod }, logger, { dev: true });
|
||||
}
|
||||
warnMissingAdapter(logger, settings);
|
||||
pipeline.manifest.checkOrigin = settings.config.security.checkOrigin && settings.buildOutput === "server";
|
||||
pipeline.setManifestData(routesList);
|
||||
}
|
||||
viteServer.watcher.on("add", rebuildManifest.bind(null, true));
|
||||
viteServer.watcher.on("unlink", rebuildManifest.bind(null, true));
|
||||
viteServer.watcher.on("change", rebuildManifest.bind(null, false));
|
||||
viteServer.watcher.on("add", rebuildManifest.bind(null, null));
|
||||
viteServer.watcher.on("unlink", rebuildManifest.bind(null, null));
|
||||
viteServer.watcher.on("change", rebuildManifest);
|
||||
function handleUnhandledRejection(rejection) {
|
||||
const error = new AstroError({
|
||||
const error = AstroError.is(rejection) ? rejection : new AstroError({
|
||||
...AstroErrorData.UnhandledRejection,
|
||||
message: AstroErrorData.UnhandledRejection.message(rejection?.stack || rejection)
|
||||
});
|
||||
const store = localStorage.getStore();
|
||||
if (store instanceof IncomingMessage) {
|
||||
const request = store;
|
||||
setRouteError(controller.state, request.url, error);
|
||||
setRouteError(controller.state, store.url, error);
|
||||
}
|
||||
const { errorWithMetadata } = recordServerError(loader, settings.config, pipeline, error);
|
||||
setTimeout(
|
||||
@@ -67,6 +100,10 @@ function createVitePluginAstroServer({
|
||||
route: "",
|
||||
handle: baseMiddleware(settings, logger)
|
||||
});
|
||||
viteServer.middlewares.stack.unshift({
|
||||
route: "",
|
||||
handle: trailingSlashMiddleware(settings)
|
||||
});
|
||||
viteServer.middlewares.use(async function astroDevHandler(request, response) {
|
||||
if (request.url === void 0 || !request.method) {
|
||||
response.writeHead(500, "Incomplete request");
|
||||
@@ -76,7 +113,7 @@ function createVitePluginAstroServer({
|
||||
localStorage.run(request, () => {
|
||||
handleRequest({
|
||||
pipeline,
|
||||
manifestData,
|
||||
routesList,
|
||||
controller,
|
||||
incomingRequest: request,
|
||||
incomingResponse: response
|
||||
@@ -93,7 +130,8 @@ function createVitePluginAstroServer({
|
||||
};
|
||||
}
|
||||
function createDevelopmentManifest(settings) {
|
||||
let i18nManifest = void 0;
|
||||
let i18nManifest;
|
||||
let csp;
|
||||
if (settings.config.i18n) {
|
||||
i18nManifest = {
|
||||
fallback: settings.config.i18n.fallback,
|
||||
@@ -104,31 +142,51 @@ function createDevelopmentManifest(settings) {
|
||||
fallbackType: toFallbackType(settings.config.i18n.routing)
|
||||
};
|
||||
}
|
||||
if (shouldTrackCspHashes(settings.config.experimental.csp)) {
|
||||
csp = {
|
||||
cspDestination: settings.adapter?.adapterFeatures?.experimentalStaticHeaders ? "adapter" : void 0,
|
||||
scriptHashes: getScriptHashes(settings.config.experimental.csp),
|
||||
scriptResources: getScriptResources(settings.config.experimental.csp),
|
||||
styleHashes: getStyleHashes(settings.config.experimental.csp),
|
||||
styleResources: getStyleResources(settings.config.experimental.csp),
|
||||
algorithm: getAlgorithm(settings.config.experimental.csp),
|
||||
directives: getDirectives(settings.config.experimental.csp),
|
||||
isStrictDynamic: getStrictDynamic(settings.config.experimental.csp)
|
||||
};
|
||||
}
|
||||
return {
|
||||
hrefRoot: settings.config.root.toString(),
|
||||
srcDir: settings.config.srcDir,
|
||||
cacheDir: settings.config.cacheDir,
|
||||
outDir: settings.config.outDir,
|
||||
buildServerDir: settings.config.build.server,
|
||||
buildClientDir: settings.config.build.client,
|
||||
publicDir: settings.config.publicDir,
|
||||
trailingSlash: settings.config.trailingSlash,
|
||||
buildFormat: settings.config.build.format,
|
||||
compressHTML: settings.config.compressHTML,
|
||||
assets: /* @__PURE__ */ new Set(),
|
||||
entryModules: {},
|
||||
routes: [],
|
||||
adapterName: settings?.adapter?.name || "",
|
||||
adapterName: settings?.adapter?.name ?? "",
|
||||
clientDirectives: settings.clientDirectives,
|
||||
renderers: [],
|
||||
base: settings.config.base,
|
||||
userAssetsBase: settings.config?.vite?.base,
|
||||
assetsPrefix: settings.config.build.assetsPrefix,
|
||||
site: settings.config.site,
|
||||
componentMetadata: /* @__PURE__ */ new Map(),
|
||||
inlinedScripts: /* @__PURE__ */ new Map(),
|
||||
i18n: i18nManifest,
|
||||
checkOrigin: settings.config.security?.checkOrigin ?? false,
|
||||
experimentalEnvGetSecretEnabled: false,
|
||||
key: createKey(),
|
||||
checkOrigin: (settings.config.security?.checkOrigin && settings.buildOutput === "server") ?? false,
|
||||
key: hasEnvironmentKey() ? getEnvironmentKey() : createKey(),
|
||||
middleware() {
|
||||
return {
|
||||
onRequest: NOOP_MIDDLEWARE_FN
|
||||
};
|
||||
}
|
||||
},
|
||||
sessionConfig: settings.config.session,
|
||||
csp
|
||||
};
|
||||
}
|
||||
export {
|
||||
|
Reference in New Issue
Block a user