From afb2b4bc3fba42992e9d1bd037931d5baf0ab5b0 Mon Sep 17 00:00:00 2001 From: Ed Stephinson Date: Tue, 7 Nov 2023 12:13:30 +0000 Subject: [PATCH] feat: add method for an inline merge of the netlify config --- packages/config/src/mutations/update.js | 40 ++++++++++++++++++------- 1 file changed, 30 insertions(+), 10 deletions(-) diff --git a/packages/config/src/mutations/update.js b/packages/config/src/mutations/update.js index 085027525c..0dffb13eb0 100644 --- a/packages/config/src/mutations/update.js +++ b/packages/config/src/mutations/update.js @@ -10,6 +10,26 @@ import { serializeToml } from '../utils/toml.js' import { applyMutations } from './apply.js' +// Performs a merge of the configuration changes with the existing `netlify.toml`, +// and returns the updated configuration +export const mergeConfig = async function ( + configMutations, + { configPath, headersPath, redirectsPath, context, branch, logs, featureFlags }, +) { + if (configMutations.length === 0) { + return + } + + const inlineConfig = applyMutations({}, configMutations) + const normalizedInlineConfig = ensureConfigPriority(inlineConfig, context, branch) + const updatedConfig = await mergeWithConfig(normalizedInlineConfig, configPath) + const configWithHeaders = await addHeaders({ config: updatedConfig, headersPath, logs, featureFlags }) + const finalConfig = await addRedirects({ config: configWithHeaders, redirectsPath, logs, featureFlags }) + const simplifiedConfig = simplifyConfig(finalConfig) + + return simplifiedConfig +} + // Persist configuration changes to `netlify.toml`. // If `netlify.toml` does not exist, creates it. Otherwise, merges the changes. export const updateConfig = async function ( @@ -26,16 +46,16 @@ export const updateConfig = async function ( featureFlags, }, ) { - if (configMutations.length === 0) { - return - } - - const inlineConfig = applyMutations({}, configMutations) - const normalizedInlineConfig = ensureConfigPriority(inlineConfig, context, branch) - const updatedConfig = await mergeWithConfig(normalizedInlineConfig, configPath) - const configWithHeaders = await addHeaders({ config: updatedConfig, headersPath, logs, featureFlags }) - const finalConfig = await addRedirects({ config: configWithHeaders, redirectsPath, logs, featureFlags }) - const simplifiedConfig = simplifyConfig(finalConfig) + const simplifiedConfig = await mergeConfig(configMutations, { + buildDir, + configPath, + headersPath, + redirectsPath, + context, + branch, + logs, + featureFlags, + }) await backupConfig({ buildDir, configPath, headersPath, redirectsPath }) await Promise.all([