From 20f9910fbdb686d370ce2e679edecb7bec3cbdb5 Mon Sep 17 00:00:00 2001 From: David Legrand Date: Fri, 7 Jun 2024 00:03:35 +0200 Subject: [PATCH] feat(config): add tasks support --- src/commands/config.js | 26 ++++++++++++++++++--- src/models/application_configuration.js | 31 ++++++++++++++++++++++--- 2 files changed, 51 insertions(+), 6 deletions(-) diff --git a/src/commands/config.js b/src/commands/config.js index 9ccb555a..5f9b3d95 100644 --- a/src/commands/config.js +++ b/src/commands/config.js @@ -25,10 +25,21 @@ export async function set (params) { const { ownerId, appId } = await Application.resolveId(appIdOrName, alias); const config = ApplicationConfiguration.getById(configurationName); + let result = null; if (config != null) { - const app = await application.update({ id: ownerId, appId }, { [config.name]: ApplicationConfiguration.parse(config, configurationValue) }).then(sendToApi); - - ApplicationConfiguration.printById(app, configurationName); + if (configurationName === 'task') { + const upperValue = configurationValue.toUpperCase(); + if (upperValue === 'TASK' || upperValue === 'REGULAR') { + result = await application.update({ id: ownerId, appId }, { instanceLifetime: upperValue }).then(sendToApi); + } + else { + throw new Error('Invalid value for task configuration: must be TASK or REGULAR'); + } + } + else { + result = await application.update({ id: ownerId, appId }, { [config.name]: ApplicationConfiguration.parse(config, configurationValue) }).then(sendToApi); + } + ApplicationConfiguration.printById(result, configurationName); } } @@ -41,6 +52,15 @@ export async function update (params) { throw new Error('No configuration to update'); } + const { task } = options; + if (task != null) { + const result = await application.update({ id: ownerId, appId }, { instanceLifetime: task }).then(sendToApi); + + // We delete the task key to avoid conflicts + delete options.task; + ApplicationConfiguration.printById(result, 'task'); + } + const app = await application.update({ id: ownerId, appId }, options).then(sendToApi); for (const configName of Object.keys(options)) { diff --git a/src/models/application_configuration.js b/src/models/application_configuration.js index a9de6715..a7bbcbb7 100644 --- a/src/models/application_configuration.js +++ b/src/models/application_configuration.js @@ -10,6 +10,7 @@ const CONFIG_KEYS = [ { id: 'sticky-sessions', name: 'stickySessions', displayName: 'Sticky sessions', kind: 'bool' }, { id: 'cancel-on-push', name: 'cancelOnPush', displayName: 'Cancel current deployment on push', kind: 'bool' }, { id: 'force-https', name: 'forceHttps', displayName: 'Force redirection of HTTP to HTTPS', kind: 'force-https' }, + { id: 'task', name: 'task', displayName: 'Deploy an application as a Clever Task', kind: 'task' }, ]; export function listAvailableIds () { @@ -36,6 +37,9 @@ function display (config, value) { case 'force-https': { return value.toLowerCase(); } + case 'task': { + return (value === 'TASK') ? 'enabled' : 'disabled'; + } default: { return String(value); } @@ -69,7 +73,8 @@ function getConfigOptions (config) { switch (config.kind) { case 'bool': case 'inverted-bool': - case 'force-https': { + case 'force-https': + case 'task': { return [ cliparse.flag(`enable-${config.id}`, { description: `Enable ${config.id}` }), cliparse.flag(`disable-${config.id}`, { description: `Disable ${config.id}` }), @@ -126,6 +131,18 @@ function parseConfigOption (config, options) { } return null; } + case 'task': { + const enable = options[`enable-${config.id}`]; + const disable = options[`disable-${config.id}`]; + if (enable && disable) { + Logger.warn(`${config.id} is both enabled and disabled, ignoring`); + } + else if (enable || disable) { + const value = (enable) ? 'TASK' : 'REGULAR'; + return [config.name, value]; + } + return null; + } default: { if (options[config.id] !== null) { return [config.name, options[config.id]]; @@ -136,7 +153,10 @@ function parseConfigOption (config, options) { } function printConfig (app, config) { - if (app[config.name] != null) { + if (config.name === 'task') { + Logger.println(`${config.displayName}: ${colors.bold(display(config, app.instance.lifetime))}`); + } + else if (app[config.name] != null) { Logger.println(`${config.displayName}: ${colors.bold(display(config, app[config.name]))}`); } } @@ -144,7 +164,12 @@ function printConfig (app, config) { export function printById (app, id) { const config = getById(id); if (config != null) { - printConfig(app, config); + if (config.name === 'task') { + Logger.println(`${config.displayName}: ${colors.bold(display(config, app.instance.lifetime))}`); + } + else { + printConfig(app, config); + } } }