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;