diff --git a/src/config/backends/backend.ts b/src/config/backends/backend.ts index ff9396241..e81b17c80 100644 --- a/src/config/backends/backend.ts +++ b/src/config/backends/backend.ts @@ -41,6 +41,12 @@ export abstract class ConfigBackend { // Example an empty string should return null. public abstract createConfigVarName(configName: string): string | null; + // Is a reboot required for the given config options? + // eslint-disable-next-line @typescript-eslint/no-unused-vars + public async isRebootRequired(_opts: ConfigOptions): Promise { + return true; + } + // Allow a chosen config backend to be initialised public async initialise(): Promise { return this; diff --git a/src/config/backends/power-fan.ts b/src/config/backends/power-fan.ts index 0a98805b6..08f81ddb7 100644 --- a/src/config/backends/power-fan.ts +++ b/src/config/backends/power-fan.ts @@ -1,6 +1,6 @@ import { isRight } from 'fp-ts/lib/Either'; import Reporter from 'io-ts-reporters'; - +import * as _ from 'lodash'; import { ConfigBackend } from './backend'; import type { ConfigOptions } from './backend'; import { schemaTypes } from '../schema-type'; @@ -146,6 +146,16 @@ export class PowerFanConfig extends ConfigBackend { return PowerFanConfig.CONFIGS.has(PowerFanConfig.stripPrefix(envVar)); } + public async isRebootRequired(opts: ConfigOptions): Promise { + const supportedOpts = _.pickBy( + _.mapKeys(opts, (_value, key) => PowerFanConfig.stripPrefix(key)), + (_value, key) => this.isSupportedConfig(key), + ); + const current = await this.getBootConfig(); + // A reboot is only required if the power mode is changing + return current.power_mode !== supportedOpts.power_mode; + } + public processConfigVarName(envVar: string): string { return PowerFanConfig.stripPrefix(envVar).toLowerCase(); } diff --git a/src/device-config.ts b/src/device-config.ts index 5e37e0333..1464fbd07 100644 --- a/src/device-config.ts +++ b/src/device-config.ts @@ -529,18 +529,21 @@ async function getBackendSteps( const { deviceType } = await config.getMany(['deviceType']); // Check for required bootConfig changes + let rebootRequired = false; for (const backend of backends) { if (changeRequired(backend, current, target, deviceType)) { steps.push({ action: 'setBootConfig', target, }); + rebootRequired = + (await backend.isRebootRequired(target)) || rebootRequired; } } return [ - // All backend steps require a reboot - ...(steps.length > 0 + // All backend steps require a reboot except fan control + ...(steps.length > 0 && rebootRequired ? [{ action: 'setRebootBreadcrumb' } as ConfigStep] : []), ...steps,