147 lines
5.1 KiB
JavaScript
147 lines
5.1 KiB
JavaScript
"use strict";
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
exports.ActionService = exports.Action = void 0;
|
|
const serviceManager_1 = require("../serviceManager");
|
|
const Debug = require("debug");
|
|
class Action {
|
|
}
|
|
exports.Action = Action;
|
|
class ActionService {
|
|
constructor() {
|
|
this.timer = undefined;
|
|
this.transport = undefined;
|
|
this.actions = new Map();
|
|
this.logger = Debug('axm:services:actions');
|
|
}
|
|
listener(data) {
|
|
this.logger(`Received new message from reverse`);
|
|
if (!data)
|
|
return false;
|
|
const actionName = data.msg ? data.msg : data.action_name ? data.action_name : data;
|
|
let action = this.actions.get(actionName);
|
|
if (typeof action !== 'object') {
|
|
return this.logger(`Received action ${actionName} but failed to find the implementation`);
|
|
}
|
|
if (!action.isScoped) {
|
|
this.logger(`Succesfully called custom action ${action.name} with arity ${action.handler.length}`);
|
|
if (action.handler.length === 2) {
|
|
let params = {};
|
|
if (typeof data === 'object') {
|
|
params = data.opts;
|
|
}
|
|
return action.handler(params, action.callback);
|
|
}
|
|
return action.handler(action.callback);
|
|
}
|
|
if (data.uuid === undefined) {
|
|
return this.logger(`Received scoped action ${action.name} but without uuid`);
|
|
}
|
|
const stream = {
|
|
send: (dt) => {
|
|
this.transport.send('axm:scoped_action:stream', {
|
|
data: dt,
|
|
uuid: data.uuid,
|
|
action_name: actionName
|
|
});
|
|
},
|
|
error: (dt) => {
|
|
this.transport.send('axm:scoped_action:error', {
|
|
data: dt,
|
|
uuid: data.uuid,
|
|
action_name: actionName
|
|
});
|
|
},
|
|
end: (dt) => {
|
|
this.transport.send('axm:scoped_action:end', {
|
|
data: dt,
|
|
uuid: data.uuid,
|
|
action_name: actionName
|
|
});
|
|
}
|
|
};
|
|
this.logger(`Succesfully called scoped action ${action.name}`);
|
|
return action.handler(data.opts || {}, stream);
|
|
}
|
|
init() {
|
|
this.transport = serviceManager_1.ServiceManager.get('transport');
|
|
if (this.transport === undefined) {
|
|
return this.logger(`Failed to load transport service`);
|
|
}
|
|
this.actions.clear();
|
|
this.transport.on('data', this.listener.bind(this));
|
|
}
|
|
destroy() {
|
|
if (this.timer !== undefined) {
|
|
clearInterval(this.timer);
|
|
}
|
|
if (this.transport !== undefined) {
|
|
this.transport.removeListener('data', this.listener.bind(this));
|
|
}
|
|
}
|
|
registerAction(actionName, opts, handler) {
|
|
if (typeof opts === 'function') {
|
|
handler = opts;
|
|
opts = undefined;
|
|
}
|
|
if (typeof actionName !== 'string') {
|
|
console.error(`You must define an name when registering an action`);
|
|
return;
|
|
}
|
|
if (typeof handler !== 'function') {
|
|
console.error(`You must define an callback when registering an action`);
|
|
return;
|
|
}
|
|
if (this.transport === undefined) {
|
|
return this.logger(`Failed to load transport service`);
|
|
}
|
|
let type = 'custom';
|
|
if (actionName.indexOf('km:') === 0 || actionName.indexOf('internal:') === 0) {
|
|
type = 'internal';
|
|
}
|
|
const reply = (data) => {
|
|
this.transport.send('axm:reply', {
|
|
at: new Date().getTime(),
|
|
action_name: actionName,
|
|
return: data
|
|
});
|
|
};
|
|
const action = {
|
|
name: actionName,
|
|
callback: reply,
|
|
handler,
|
|
type,
|
|
isScoped: false,
|
|
arity: handler.length,
|
|
opts
|
|
};
|
|
this.logger(`Succesfully registered custom action ${action.name}`);
|
|
this.actions.set(actionName, action);
|
|
this.transport.addAction(action);
|
|
}
|
|
scopedAction(actionName, handler) {
|
|
if (typeof actionName !== 'string') {
|
|
console.error(`You must define an name when registering an action`);
|
|
return -1;
|
|
}
|
|
if (typeof handler !== 'function') {
|
|
console.error(`You must define an callback when registering an action`);
|
|
return -1;
|
|
}
|
|
if (this.transport === undefined) {
|
|
return this.logger(`Failed to load transport service`);
|
|
}
|
|
const action = {
|
|
name: actionName,
|
|
handler,
|
|
type: 'scoped',
|
|
isScoped: true,
|
|
arity: handler.length,
|
|
opts: null
|
|
};
|
|
this.logger(`Succesfully registered scoped action ${action.name}`);
|
|
this.actions.set(actionName, action);
|
|
this.transport.addAction(action);
|
|
}
|
|
}
|
|
exports.ActionService = ActionService;
|