n8n
Version:
n8n Workflow Automation Tool
167 lines • 8.53 kB
JavaScript
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.getWorkerCommandReceivedHandler = void 0;
const n8n_workflow_1 = require("n8n-workflow");
const typedi_1 = __importDefault(require("typedi"));
const RedisServiceHelper_1 = require("../../../services/redis/RedisServiceHelper");
const os = __importStar(require("os"));
const License_1 = require("../../../License");
const MessageEventBus_1 = require("../../../eventbus/MessageEventBus/MessageEventBus");
const ExternalSecretsManager_ee_1 = require("../../../ExternalSecrets/ExternalSecretsManager.ee");
const helpers_1 = require("../helpers");
const Logger_1 = require("../../../Logger");
const constants_1 = require("../../../constants");
function getWorkerCommandReceivedHandler(options) {
return async (channel, messageString) => {
if (channel === RedisServiceHelper_1.COMMAND_REDIS_CHANNEL) {
if (!messageString)
return;
const logger = typedi_1.default.get(Logger_1.Logger);
let message;
try {
message = (0, n8n_workflow_1.jsonParse)(messageString);
}
catch {
logger.debug(`Received invalid message via channel ${RedisServiceHelper_1.COMMAND_REDIS_CHANNEL}: "${messageString}"`);
return;
}
if (message) {
logger.debug(`RedisCommandHandler(worker): Received command message ${message.command} from ${message.senderId}`);
if (message.targets && !message.targets.includes(options.queueModeId)) {
return;
}
switch (message.command) {
case 'getStatus':
if (!(0, helpers_1.debounceMessageReceiver)(message, 500))
return;
await options.redisPublisher.publishToWorkerChannel({
workerId: options.queueModeId,
command: 'getStatus',
payload: {
workerId: options.queueModeId,
runningJobsSummary: options.getRunningJobsSummary(),
freeMem: os.freemem(),
totalMem: os.totalmem(),
uptime: process.uptime(),
loadAvg: os.loadavg(),
cpus: (0, helpers_1.getOsCpuString)(),
arch: os.arch(),
platform: os.platform(),
hostname: os.hostname(),
interfaces: Object.values(os.networkInterfaces()).flatMap((interfaces) => {
var _a;
return (_a = (interfaces !== null && interfaces !== void 0 ? interfaces : [])) === null || _a === void 0 ? void 0 : _a.map((net) => ({
family: net.family,
address: net.address,
internal: net.internal,
}));
}),
version: constants_1.N8N_VERSION,
},
});
break;
case 'getId':
if (!(0, helpers_1.debounceMessageReceiver)(message, 500))
return;
await options.redisPublisher.publishToWorkerChannel({
workerId: options.queueModeId,
command: 'getId',
});
break;
case 'restartEventBus':
if (!(0, helpers_1.debounceMessageReceiver)(message, 500))
return;
try {
await typedi_1.default.get(MessageEventBus_1.MessageEventBus).restart();
await options.redisPublisher.publishToWorkerChannel({
workerId: options.queueModeId,
command: 'restartEventBus',
payload: {
result: 'success',
},
});
}
catch (error) {
await options.redisPublisher.publishToWorkerChannel({
workerId: options.queueModeId,
command: 'restartEventBus',
payload: {
result: 'error',
error: error.message,
},
});
}
break;
case 'reloadExternalSecretsProviders':
if (!(0, helpers_1.debounceMessageReceiver)(message, 500))
return;
try {
await typedi_1.default.get(ExternalSecretsManager_ee_1.ExternalSecretsManager).reloadAllProviders();
await options.redisPublisher.publishToWorkerChannel({
workerId: options.queueModeId,
command: 'reloadExternalSecretsProviders',
payload: {
result: 'success',
},
});
}
catch (error) {
await options.redisPublisher.publishToWorkerChannel({
workerId: options.queueModeId,
command: 'reloadExternalSecretsProviders',
payload: {
result: 'error',
error: error.message,
},
});
}
break;
case 'reloadLicense':
if (!(0, helpers_1.debounceMessageReceiver)(message, 500))
return;
await typedi_1.default.get(License_1.License).reload();
break;
case 'stopWorker':
if (!(0, helpers_1.debounceMessageReceiver)(message, 500))
return;
break;
default:
if (message.command === 'relay-execution-lifecycle-event' ||
message.command === 'clear-test-webhooks') {
break;
}
logger.debug(`Received unknown command via channel ${RedisServiceHelper_1.COMMAND_REDIS_CHANNEL}: "${message.command}"`);
break;
}
}
}
};
}
exports.getWorkerCommandReceivedHandler = getWorkerCommandReceivedHandler;
//# sourceMappingURL=handleCommandMessageWorker.js.map
;