ios.js
2.37 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
var parameters = require('../helpers/parameters');
var properties = require('../helpers/properties');
var queue_helper = require('../helpers/queue');
var exec = require('child_process').exec, child;
var uuid = require('node-uuid');
var fs = require('fs');
var kue = require('kue'),
queue = kue.createQueue();
var logger = require('../logsystem/main.js');
function init(req, res) {
logger.incrementService("outros", "requisicoes");
var id = uuid.v4();
/* Verifica se os paramêtros [transparencia, texto] possuem algum valor */
if ((req.body.transparencia === '') || (req.body.texto === '')) {
res.send(500, parameters.errorMessage('O valor de algum parâmetro está vazio'));
return;
}
/* Verifica se o paramêtro [transparencia] possui os únicos valores possíveis [opaco, transparente] */
if (parameters.checkTransparency(req.body.transparencia) === false) {
res.send(500, parameters.errorMessage('Parâmetros insuficientes ou inválidos'));
return;
}
/* Cria a linha de comando */
var command_line = 'echo ' + req.body.texto + ' >> text_files/' + id + ' && mkdir uploads/' + id + ' && vlibras_user/vlibras-core/./vlibras ' + parameters.getServiceType(req.body.servico) + ' text_files/' +
id + ' ' + parameters.getTransparency(req.body.transparencia) + ' ' + id + ' IOS > /tmp/core_log 2>&1';
console.log(command_line);
/* Executa a linha de comando */
// child = exec(command_line, function(err, stdout, stderr) {
// // [stdout] = vlibras-core output
// });
var child;
var job = queue.create('exec_command_line' + id, {
title: 'Command Line for: ' + req.body.servico,
command_line: command_line
}).removeOnComplete( true ).save();
queue.process('exec_command_line' + id, function(job, done){
child = queue_helper.exec_command_line(job.data.command_line, done);
});
job.on('complete', function() {
/* Listener que dispara quando a requisição ao core finaliza */
child.on('close', function(code, signal){
res.send(200, { 'response' : 'http://' + properties.SERVER_IP + ':' + properties.port + '/' + id + '.mp4' });
logger.incrementService("outros", "traducoes");
});
/* Listener que dispara quando a requisição ao core da erro */
child.on('error', function(code, signal){
res.send(500, parameters.errorMessage('Erro na chamada ao core'));
logger.incrementError("1", err);
});
});
}
module.exports.init = init;