n8n
Version:
n8n Workflow Automation Tool
88 lines • 3.78 kB
JavaScript
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.TaskRunnerService = void 0;
const typedi_1 = require("typedi");
const logger_service_1 = require("../logging/logger.service");
const task_broker_service_1 = require("./task-broker.service");
function heartbeat() {
this.isAlive = true;
}
let TaskRunnerService = class TaskRunnerService {
constructor(logger, taskBroker) {
this.logger = logger;
this.taskBroker = taskBroker;
this.runnerConnections = new Map();
}
sendMessage(id, message) {
this.runnerConnections.get(id)?.send(JSON.stringify(message));
}
add(id, connection) {
connection.isAlive = true;
connection.on('pong', heartbeat);
let isConnected = false;
const onMessage = (data) => {
try {
const buffer = Array.isArray(data) ? Buffer.concat(data) : Buffer.from(data);
const message = JSON.parse(buffer.toString('utf8'));
if (!isConnected && message.type !== 'runner:info') {
return;
}
else if (!isConnected && message.type === 'runner:info') {
this.removeConnection(id);
isConnected = true;
this.runnerConnections.set(id, connection);
this.taskBroker.registerRunner({
id,
taskTypes: message.types,
lastSeen: new Date(),
name: message.name,
}, this.sendMessage.bind(this, id));
this.logger.info(`Runner "${message.name}"(${id}) has been registered`);
return;
}
void this.taskBroker.onRunnerMessage(id, message);
}
catch (error) {
this.logger.error(`Couldn't parse message from runner "${id}"`, {
error: error,
id,
data,
});
}
};
connection.once('close', () => {
connection.off('pong', heartbeat);
connection.off('message', onMessage);
this.removeConnection(id);
});
connection.on('message', onMessage);
connection.send(JSON.stringify({ type: 'broker:inforequest' }));
}
removeConnection(id) {
const connection = this.runnerConnections.get(id);
if (connection) {
this.taskBroker.deregisterRunner(id);
connection.close();
this.runnerConnections.delete(id);
}
}
handleRequest(req, _res) {
this.add(req.query.id, req.ws);
}
};
exports.TaskRunnerService = TaskRunnerService;
exports.TaskRunnerService = TaskRunnerService = __decorate([
(0, typedi_1.Service)(),
__metadata("design:paramtypes", [logger_service_1.Logger,
task_broker_service_1.TaskBroker])
], TaskRunnerService);
//# sourceMappingURL=runner-ws-server.js.map
;