From 0ec66bfb421c4eb3c6e92144c7563d8d3ea4ac69 Mon Sep 17 00:00:00 2001 From: Thomas S Date: Tue, 3 Jan 2023 11:45:03 +0100 Subject: [PATCH] feat(core): Add compatibility to redis > 6 ACLs system using username in queue-mode (#5048) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit feat(redis): add compatibility to redis > 6 ACLs system using username Co-authored-by: कारतोफ्फेलस्क्रिप्ट™ --- packages/cli/src/commands/start.ts | 4 ++++ packages/cli/src/commands/webhook.ts | 4 ++++ packages/cli/src/config/schema.ts | 6 ++++++ 3 files changed, 14 insertions(+) diff --git a/packages/cli/src/commands/start.ts b/packages/cli/src/commands/start.ts index c7a7fb1884..53075f1abd 100644 --- a/packages/cli/src/commands/start.ts +++ b/packages/cli/src/commands/start.ts @@ -350,6 +350,7 @@ export class Start extends Command { if (config.getEnv('executions.mode') === 'queue') { const redisHost = config.getEnv('queue.bull.redis.host'); + const redisUsername = config.getEnv('queue.bull.redis.username'); const redisPassword = config.getEnv('queue.bull.redis.password'); const redisPort = config.getEnv('queue.bull.redis.port'); const redisDB = config.getEnv('queue.bull.redis.db'); @@ -383,6 +384,9 @@ export class Start extends Command { if (redisHost) { settings.host = redisHost; } + if (redisUsername) { + settings.username = redisUsername; + } if (redisPassword) { settings.password = redisPassword; } diff --git a/packages/cli/src/commands/webhook.ts b/packages/cli/src/commands/webhook.ts index d8f4a0f97d..7ad1305b39 100644 --- a/packages/cli/src/commands/webhook.ts +++ b/packages/cli/src/commands/webhook.ts @@ -159,6 +159,7 @@ export class Webhook extends Command { if (config.getEnv('executions.mode') === 'queue') { const redisHost = config.getEnv('queue.bull.redis.host'); + const redisUsername = config.getEnv('queue.bull.redis.username'); const redisPassword = config.getEnv('queue.bull.redis.password'); const redisPort = config.getEnv('queue.bull.redis.port'); const redisDB = config.getEnv('queue.bull.redis.db'); @@ -192,6 +193,9 @@ export class Webhook extends Command { if (redisHost) { settings.host = redisHost; } + if (redisUsername) { + settings.username = redisUsername; + } if (redisPassword) { settings.password = redisPassword; } diff --git a/packages/cli/src/config/schema.ts b/packages/cli/src/config/schema.ts index ee459209a0..aeacab0b87 100644 --- a/packages/cli/src/config/schema.ts +++ b/packages/cli/src/config/schema.ts @@ -380,6 +380,12 @@ export const schema = { default: 10000, env: 'QUEUE_BULL_REDIS_TIMEOUT_THRESHOLD', }, + username: { + doc: 'Redis Username (needs Redis >= 6)', + format: String, + default: '', + env: 'QUEUE_BULL_REDIS_USERNAME', + }, }, queueRecoveryInterval: { doc: 'If > 0 enables an active polling to the queue that can recover for Redis crashes. Given in seconds; 0 is disabled. May increase Redis traffic significantly.',