Refactor merge server config (#7639)
This commit is contained in:
parent
4ce2ba972a
commit
bde08c4b14
3 changed files with 26 additions and 28 deletions
|
@ -6,6 +6,7 @@ import * as colors from 'kleur/colors';
|
||||||
import path from 'path';
|
import path from 'path';
|
||||||
import { fileURLToPath, pathToFileURL } from 'url';
|
import { fileURLToPath, pathToFileURL } from 'url';
|
||||||
import { AstroError, AstroErrorData } from '../errors/index.js';
|
import { AstroError, AstroErrorData } from '../errors/index.js';
|
||||||
|
import { mergeConfig } from './merge.js';
|
||||||
import { createRelativeSchema } from './schema.js';
|
import { createRelativeSchema } from './schema.js';
|
||||||
import { loadConfigWithVite } from './vite-load.js';
|
import { loadConfigWithVite } from './vite-load.js';
|
||||||
|
|
||||||
|
@ -114,28 +115,18 @@ export function resolveRoot(cwd?: string | URL): string {
|
||||||
|
|
||||||
/** Merge CLI flags & user config object (CLI flags take priority) */
|
/** Merge CLI flags & user config object (CLI flags take priority) */
|
||||||
function mergeCLIFlags(astroConfig: AstroUserConfig, flags: CLIFlags) {
|
function mergeCLIFlags(astroConfig: AstroUserConfig, flags: CLIFlags) {
|
||||||
astroConfig.server = astroConfig.server || {};
|
return mergeConfig(astroConfig, {
|
||||||
astroConfig.markdown = astroConfig.markdown || {};
|
site: flags.site,
|
||||||
astroConfig.experimental = astroConfig.experimental || {};
|
base: flags.base,
|
||||||
if (typeof flags.site === 'string') astroConfig.site = flags.site;
|
markdown: {
|
||||||
if (typeof flags.base === 'string') astroConfig.base = flags.base;
|
drafts: flags.drafts,
|
||||||
if (typeof flags.drafts === 'boolean') astroConfig.markdown.drafts = flags.drafts;
|
},
|
||||||
if (typeof flags.port === 'number') {
|
server: {
|
||||||
// @ts-expect-error astroConfig.server may be a function, but TS doesn't like attaching properties to a function.
|
port: flags.port,
|
||||||
// TODO: Come back here and refactor to remove this expected error.
|
host: flags.host,
|
||||||
astroConfig.server.port = flags.port;
|
open: flags.open,
|
||||||
}
|
},
|
||||||
if (typeof flags.host === 'string' || typeof flags.host === 'boolean') {
|
});
|
||||||
// @ts-expect-error astroConfig.server may be a function, but TS doesn't like attaching properties to a function.
|
|
||||||
// TODO: Come back here and refactor to remove this expected error.
|
|
||||||
astroConfig.server.host = flags.host;
|
|
||||||
}
|
|
||||||
if (typeof flags.open === 'boolean') {
|
|
||||||
// @ts-expect-error astroConfig.server may be a function, but TS doesn't like attaching properties to a function.
|
|
||||||
// TODO: Come back here and refactor to remove this expected error.
|
|
||||||
astroConfig.server.open = flags.open;
|
|
||||||
}
|
|
||||||
return astroConfig;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
async function search(fsMod: typeof fs, root: string) {
|
async function search(fsMod: typeof fs, root: string) {
|
||||||
|
|
|
@ -25,6 +25,18 @@ function mergeConfigRecursively(
|
||||||
merged[key] = mergeViteConfig(existing, value);
|
merged[key] = mergeViteConfig(existing, value);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
if (key === 'server' && rootPath === '') {
|
||||||
|
// server config can be a function or an object, if one of the two values is a function,
|
||||||
|
// create a new wrapper function that merges them
|
||||||
|
if (typeof existing === 'function' || typeof value === 'function') {
|
||||||
|
merged[key] = (...args: any[]) => {
|
||||||
|
const existingConfig = typeof existing === 'function' ? existing(...args) : existing;
|
||||||
|
const valueConfig = typeof value === 'function' ? value(...args) : value;
|
||||||
|
return mergeConfigRecursively(existingConfig, valueConfig, key);
|
||||||
|
};
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (Array.isArray(existing) || Array.isArray(value)) {
|
if (Array.isArray(existing) || Array.isArray(value)) {
|
||||||
merged[key] = [...arraify(existing ?? []), ...arraify(value ?? [])];
|
merged[key] = [...arraify(existing ?? []), ...arraify(value ?? [])];
|
||||||
|
|
|
@ -299,12 +299,7 @@ export function createRelativeSchema(cmd: string, fileProtocolRoot: URL) {
|
||||||
// preprocess
|
// preprocess
|
||||||
(val) => {
|
(val) => {
|
||||||
if (typeof val === 'function') {
|
if (typeof val === 'function') {
|
||||||
const result = val({ command: cmd === 'dev' ? 'dev' : 'preview' });
|
return val({ command: cmd === 'dev' ? 'dev' : 'preview' });
|
||||||
// @ts-expect-error revive attached prop added from CLI flags
|
|
||||||
if (val.port) result.port = val.port;
|
|
||||||
// @ts-expect-error revive attached prop added from CLI flags
|
|
||||||
if (val.host) result.host = val.host;
|
|
||||||
return result;
|
|
||||||
} else {
|
} else {
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue