Commit 505a1abd4e55eb78f7e7065b0a708479df934ec6
Exists in
master
and in
1 other branch
resolve problema no merge
Showing
17 changed files
with
310 additions
and
29 deletions
Show diff stats
config/main.js
... | ... | @@ -46,6 +46,21 @@ exports.getCapacityLogPath = function () { |
46 | 46 | return this.getLogByName('capacity'); |
47 | 47 | }; |
48 | 48 | |
49 | +exports.isBloqueante = function () { | |
50 | + //1 para bloqueante, 2 para nao bloqueante e 3 pra aceitar os dois | |
51 | + return this.getServiceType() === 1; | |
52 | +}; | |
53 | + | |
54 | +exports.isNaoBloqueante = function () { | |
55 | + //1 para bloqueante, 2 para nao bloqueante e 3 pra aceitar os dois | |
56 | + return this.getServiceType() === 2; | |
57 | +}; | |
58 | + | |
59 | +exports.isAmbos = function () { | |
60 | + //1 para bloqueante, 2 para nao bloqueante e 3 pra aceitar os dois | |
61 | + return this.getServiceType() === 3; | |
62 | +}; | |
63 | + | |
49 | 64 | exports.canRunOnBox = function (service) { |
50 | 65 | //1 para bloqueante, 2 para nao bloqueante e 3 pra aceitar os dois |
51 | 66 | var serviceType = parseInt(this.getServiceType()); | ... | ... |
endpoints/audio.js
... | ... | @@ -6,6 +6,7 @@ var core = require('../helpers/core'); |
6 | 6 | var uuid = require('node-uuid'); |
7 | 7 | var mkdirp = require('mkdirp'); |
8 | 8 | var async = require('async'); |
9 | +var logger = require('../logsystem/main.js'); | |
9 | 10 | |
10 | 11 | function init(req, res) { |
11 | 12 | res.set("Content-Type", "application/json"); |
... | ... | @@ -21,7 +22,7 @@ function init(req, res) { |
21 | 22 | res.send(500, parameters.errorMessage('Parâmetros insuficientes ou inválidos')); |
22 | 23 | return; |
23 | 24 | } |
24 | - | |
25 | + | |
25 | 26 | process(req, res); |
26 | 27 | }; |
27 | 28 | |
... | ... | @@ -29,7 +30,7 @@ function process(req, res) { |
29 | 30 | var id = uuid.v4(); |
30 | 31 | var folder = properties.uploads_folder + id; |
31 | 32 | var locals = {}; |
32 | - | |
33 | + | |
33 | 34 | async.series([ |
34 | 35 | // Cria a pasta apropriada |
35 | 36 | function(callback) { |
... | ... | @@ -59,7 +60,9 @@ function process(req, res) { |
59 | 60 | try { |
60 | 61 | callCore(id, locals.audio, req, res); |
61 | 62 | callback(); |
63 | + logger.incrementService("outros", "traducoes"); | |
62 | 64 | } catch (err) { |
65 | + logger.incrementError("1", err); | |
63 | 66 | callback(err); |
64 | 67 | } |
65 | 68 | } | ... | ... |
endpoints/ios.js
... | ... | @@ -6,6 +6,7 @@ var uuid = require('node-uuid'); |
6 | 6 | var fs = require('fs'); |
7 | 7 | var kue = require('kue'), |
8 | 8 | queue = kue.createQueue(); |
9 | +var logger = require('../logsystem/main.js'); | |
9 | 10 | |
10 | 11 | function init(req, res) { |
11 | 12 | |
... | ... | @@ -48,11 +49,13 @@ function init(req, res) { |
48 | 49 | /* Listener que dispara quando a requisição ao core finaliza */ |
49 | 50 | child.on('close', function(code, signal){ |
50 | 51 | res.send(200, { 'response' : 'http://' + properties.SERVER_IP + ':' + properties.port + '/' + id + '.mp4' }); |
52 | + logger.incrementService("outros", "traducoes"); | |
51 | 53 | }); |
52 | 54 | |
53 | 55 | /* Listener que dispara quando a requisição ao core da erro */ |
54 | 56 | child.on('error', function(code, signal){ |
55 | 57 | res.send(500, parameters.errorMessage('Erro na chamada ao core')); |
58 | + logger.incrementError("1", err); | |
56 | 59 | }); |
57 | 60 | }); |
58 | 61 | } | ... | ... |
endpoints/legenda.js
... | ... | @@ -6,6 +6,7 @@ var uuid = require('node-uuid'); |
6 | 6 | var fs = require('fs'); |
7 | 7 | var kue = require('kue'), |
8 | 8 | queue = kue.createQueue(); |
9 | +var logger = require('../logsystem/main.js'); | |
9 | 10 | |
10 | 11 | function init(req, res) { |
11 | 12 | |
... | ... | @@ -57,20 +58,22 @@ function init(req, res) { |
57 | 58 | queue.process('exec_command_line', function(job, done){ |
58 | 59 | child = queue_helper.exec_command_line(job.data.command_line, done); |
59 | 60 | }); |
60 | - | |
61 | + | |
61 | 62 | job.on('complete', function() { |
62 | 63 | /* Listener que dispara quando a requisição ao core finaliza */ |
63 | 64 | child.on('close', function(code, signal){ |
64 | 65 | res.send(200, { 'response' : 'http://' + properties.SERVER_IP + ':' + properties.port + '/' + id + '.flv' }); |
66 | + logger.incrementService("outros", "traducoes"); | |
65 | 67 | }); |
66 | 68 | |
67 | 69 | /* Listener que dispara quando a requisição ao core da erro */ |
68 | 70 | child.on('error', function(code, signal){ |
69 | 71 | res.send(500, parameters.errorMessage('Erro na chamada ao core')); |
72 | + logger.incrementError("1", err); | |
70 | 73 | }); |
71 | - }) | |
74 | + }); | |
72 | 75 | |
73 | 76 | }); |
74 | -}; | |
77 | +} | |
75 | 78 | |
76 | 79 | module.exports.init = init; | ... | ... |
endpoints/texto.js
... | ... | @@ -7,6 +7,7 @@ var uuid = require('node-uuid'); |
7 | 7 | var fs = require('fs'); |
8 | 8 | var kue = require('kue'), |
9 | 9 | queue = kue.createQueue(); |
10 | +var logger = require('../logsystem/main.js'); | |
10 | 11 | |
11 | 12 | function init(req, res, Request) { |
12 | 13 | |
... | ... | @@ -34,8 +35,8 @@ function init(req, res, Request) { |
34 | 35 | |
35 | 36 | db.create(request_object, function(result) { |
36 | 37 | if (result !== null) { |
37 | - // TODO retornar ID do video | |
38 | 38 | res.send(200, { 'status': 'Requisição ' + result.id + ' cadastrada com sucesso.', 'video_id': result.id}); |
39 | + logger.incrementService("outros", "traducoes"); | |
39 | 40 | } else { |
40 | 41 | res.send(500, { 'error': 'Erro na criação da requisição.'}); |
41 | 42 | } |
... | ... | @@ -62,11 +63,13 @@ function init(req, res, Request) { |
62 | 63 | // res.send(200, { 'response' : 'http://' + properties.SERVER_IP + ':' + properties.port + '/' + id + '.webm' }); |
63 | 64 | db.update(request_object, 'Completed', function(result) { |
64 | 65 | }); |
66 | + logger.incrementService("outros", "traducoes"); | |
65 | 67 | }); |
66 | 68 | |
67 | 69 | /* Listener que dispara quando a requisição ao core da erro */ |
68 | 70 | child.on('error', function(code, signal){ |
69 | 71 | res.send(500, parameters.errorMessage('Erro na chamada ao core')); |
72 | + logger.incrementError("1", 'Erro na chamada ao core'); | |
70 | 73 | db.update(request_object, 'Error', function(result) { |
71 | 74 | }); |
72 | 75 | }); | ... | ... |
endpoints/video.js
... | ... | @@ -6,6 +6,7 @@ var core = require('../helpers/core'); |
6 | 6 | var uuid = require('node-uuid'); |
7 | 7 | var mkdirp = require('mkdirp'); |
8 | 8 | var async = require('async'); |
9 | +var logger = require('../logsystem/main.js'); | |
9 | 10 | |
10 | 11 | function init(req, res) { |
11 | 12 | res.set("Content-Type", "application/json"); |
... | ... | @@ -58,8 +59,10 @@ function process(req, res) { |
58 | 59 | // Faz a chamada ao core |
59 | 60 | try { |
60 | 61 | callCore(id, locals.video, locals.subtitle, req, res); |
62 | + logger.incrementService("videos", "traducoes"); | |
61 | 63 | callback(); |
62 | 64 | } catch (err) { |
65 | + logger.incrementError("1", err); | |
63 | 66 | callback(err); |
64 | 67 | } |
65 | 68 | } | ... | ... |
endpoints/video_legenda.js
... | ... | @@ -6,6 +6,7 @@ var core = require('../helpers/core'); |
6 | 6 | var uuid = require('node-uuid'); |
7 | 7 | var mkdirp = require('mkdirp'); |
8 | 8 | var async = require('async'); |
9 | +var logger = require('../logsystem/main.js'); | |
9 | 10 | |
10 | 11 | function init(req, res) { |
11 | 12 | res.set("Content-Type", "application/json"); |
... | ... | @@ -23,7 +24,7 @@ function init(req, res) { |
23 | 24 | } |
24 | 25 | |
25 | 26 | process(req, res); |
26 | -}; | |
27 | +} | |
27 | 28 | |
28 | 29 | function process(req, res) { |
29 | 30 | var id = uuid.v4(); |
... | ... | @@ -59,8 +60,10 @@ function process(req, res) { |
59 | 60 | try { |
60 | 61 | callCore(id, locals.video, locals.subtitle, req, res); |
61 | 62 | callback(); |
63 | + logger.incrementService("outros", "traducoes"); | |
62 | 64 | } catch (err) { |
63 | 65 | callback(err); |
66 | + logger.incrementError("1", err); | |
64 | 67 | } |
65 | 68 | } |
66 | 69 | ], function(err) { | ... | ... |
helpers/core.js
... | ... | @@ -7,6 +7,7 @@ var querystring = require('querystring'); |
7 | 7 | var exec = require('child_process').exec, child; |
8 | 8 | var kue = require('kue'), |
9 | 9 | queue = kue.createQueue(); |
10 | +var logger = require('../logsystem/main.js'); | |
10 | 11 | |
11 | 12 | function call(id, command_line, req, res) { |
12 | 13 | /* Executa a linha de comando */ |
... | ... | @@ -66,6 +67,7 @@ function call(id, command_line, req, res) { |
66 | 67 | var data = querystring.stringify({ 'response' : 'http://' + properties.SERVER_IP + ':' + properties.port + '/' + id + '.mp4', 'id' : id }); |
67 | 68 | } else { |
68 | 69 | var data = querystring.stringify({ 'error': 'Erro no Core', 'code': code, 'id' : id }); |
70 | + logger.incrementError("2"); | |
69 | 71 | } |
70 | 72 | |
71 | 73 | // Chama o callback |
... | ... | @@ -76,7 +78,7 @@ function call(id, command_line, req, res) { |
76 | 78 | child.on('error', function(code, signal) { |
77 | 79 | var path = url.parse(req.body.callback); |
78 | 80 | var data = querystring.stringify( { 'error': 'Erro na chamada ao core', 'code': code, 'id': id } ); |
79 | - | |
81 | + logger.incrementError("2"); | |
80 | 82 | requests.postRequest(path, data); |
81 | 83 | }); |
82 | 84 | ... | ... |
helpers/files.js
1 | 1 | var parameters = require('../helpers/parameters'); |
2 | - | |
3 | 2 | var http = require('http'); |
4 | 3 | var fs = require('fs'); |
4 | +var logger = require('../logsystem/main.js'); | |
5 | 5 | |
6 | -/* | |
6 | +/* | |
7 | 7 | * Função que processa o vídeo (seja baixando, seja pegando o vídeo enviado) |
8 | 8 | * Deve retornar um objeto contendo o nome e o caminho |
9 | 9 | */ |
... | ... | @@ -15,12 +15,13 @@ function downloadAndMoveVideo(folder, req, locals, callback) { |
15 | 15 | // Se a validação falhar |
16 | 16 | if (parameters.checkVideo(req.files.video.name) === false) { |
17 | 17 | var error = 'Vídeo enviado com extensão inválida'; |
18 | + logger.incrementError("2"); | |
18 | 19 | return callback(error); |
19 | - } | |
20 | + } | |
20 | 21 | |
21 | 22 | /* Move o vídeo submetido para a pasta com o seu ID correspondente */ |
22 | 23 | try { |
23 | - fs.renameSync(req.files.video.path, folder + '/' + req.files.video.name); | |
24 | + fs.renameSync(req.files.video.path, folder + '/' + req.files.video.name); | |
24 | 25 | } catch (err) { |
25 | 26 | callback("Erro ao mover o vídeo submetido: " + err); |
26 | 27 | } |
... | ... | @@ -70,9 +71,9 @@ function downloadAndMoveVideo(folder, req, locals, callback) { |
70 | 71 | locals.video = { |
71 | 72 | 'path': path |
72 | 73 | } |
73 | - | |
74 | + | |
74 | 75 | // Chama o callback para prosseguir execução |
75 | - callback(); | |
76 | + callback(); | |
76 | 77 | }); |
77 | 78 | }); |
78 | 79 | |
... | ... | @@ -89,7 +90,7 @@ function downloadAndMoveVideo(folder, req, locals, callback) { |
89 | 90 | } |
90 | 91 | } |
91 | 92 | |
92 | -/* | |
93 | +/* | |
93 | 94 | * Função que processa a legenda (seja baixando, seja pegando o vídeo enviado) |
94 | 95 | * Deve retornar um objeto contendo o nome e o caminho |
95 | 96 | */ |
... | ... | @@ -101,12 +102,13 @@ function downloadAndMoveSubtitle(folder, req, locals, callback) { |
101 | 102 | // Se a validação falhar |
102 | 103 | if (parameters.checkSubtitle(req.files.legenda.name) === false) { |
103 | 104 | var error = 'Legenda enviado com extensão inválida'; |
105 | + logger.incrementError("3"); | |
104 | 106 | return callback(error); |
105 | - } | |
107 | + } | |
106 | 108 | |
107 | 109 | /* Move o vídeo submetido para a pasta com o seu ID correspondente */ |
108 | 110 | try { |
109 | - fs.renameSync(req.files.legenda.path, folder + '/' + req.files.legenda.name); | |
111 | + fs.renameSync(req.files.legenda.path, folder + '/' + req.files.legenda.name); | |
110 | 112 | } catch (err) { |
111 | 113 | callback("Erro ao mover a legenda submetida: " + err); |
112 | 114 | } |
... | ... | @@ -156,9 +158,9 @@ function downloadAndMoveSubtitle(folder, req, locals, callback) { |
156 | 158 | locals.subtitle = { |
157 | 159 | 'path': path |
158 | 160 | } |
159 | - | |
161 | + | |
160 | 162 | // Chama o callback para prosseguir execução |
161 | - callback(); | |
163 | + callback(); | |
162 | 164 | }); |
163 | 165 | }); |
164 | 166 | |
... | ... | @@ -184,11 +186,11 @@ function downloadAndMoveAudio(folder, req, locals, callback) { |
184 | 186 | if (parameters.checkAudio(req.files.audio.name) === false) { |
185 | 187 | var error = 'Áudio enviado com extensão inválida'; |
186 | 188 | return callback(error); |
187 | - } | |
189 | + } | |
188 | 190 | |
189 | 191 | /* Move o áudio submetido para a pasta com o seu ID correspondente */ |
190 | 192 | try { |
191 | - fs.renameSync(req.files.audio.path, folder + '/' + req.files.audio.name); | |
193 | + fs.renameSync(req.files.audio.path, folder + '/' + req.files.audio.name); | |
192 | 194 | } catch (err) { |
193 | 195 | callback("Erro ao mover o áudio submetido: " + err); |
194 | 196 | } |
... | ... | @@ -238,9 +240,9 @@ function downloadAndMoveAudio(folder, req, locals, callback) { |
238 | 240 | locals.audio = { |
239 | 241 | 'path': path |
240 | 242 | } |
241 | - | |
243 | + | |
242 | 244 | // Chama o callback para prosseguir execução |
243 | - callback(); | |
245 | + callback(); | |
244 | 246 | }); |
245 | 247 | }); |
246 | 248 | |
... | ... | @@ -259,4 +261,4 @@ function downloadAndMoveAudio(folder, req, locals, callback) { |
259 | 261 | |
260 | 262 | module.exports.downloadAndMoveVideo = downloadAndMoveVideo; |
261 | 263 | module.exports.downloadAndMoveSubtitle = downloadAndMoveSubtitle; |
262 | -module.exports.downloadAndMoveAudio = downloadAndMoveAudio; | |
263 | 264 | \ No newline at end of file |
265 | +module.exports.downloadAndMoveAudio = downloadAndMoveAudio; | ... | ... |
... | ... | @@ -0,0 +1,22 @@ |
1 | +{ | |
2 | + "resumo": { | |
3 | + "bloqueante": { | |
4 | + "1": 2, | |
5 | + "2": 0, | |
6 | + "3": 0, | |
7 | + "4": 1 | |
8 | + }, | |
9 | + "nao-bloqueante": { | |
10 | + "1": 0, | |
11 | + "2": 0, | |
12 | + "3": 0, | |
13 | + "4": 0 | |
14 | + } | |
15 | + }, | |
16 | + "detalhado": { | |
17 | + "1": "detalhe do erro", | |
18 | + "2": "detalhe", | |
19 | + "3": "detalhe", | |
20 | + "4": "Rota nao encontrada" | |
21 | + } | |
22 | +} | |
0 | 23 | \ No newline at end of file | ... | ... |
... | ... | @@ -0,0 +1,23 @@ |
1 | +{ | |
2 | + "resumo": { | |
3 | + "bloqueante": { | |
4 | + "1": 0, | |
5 | + "2": 0, | |
6 | + "3": 0, | |
7 | + "4": 0 | |
8 | + }, | |
9 | + "nao-bloqueante": { | |
10 | + "1": 0, | |
11 | + "2": 0, | |
12 | + "3": 0, | |
13 | + "4": 0 | |
14 | + } | |
15 | + }, | |
16 | + "detalhado": { | |
17 | + "1": "detalhe", | |
18 | + "2": "detalhe", | |
19 | + "3": "detalhe", | |
20 | + "4": "detalhe" | |
21 | + | |
22 | + } | |
23 | +} | ... | ... |
logsystem/main.coffee
1 | -config = require('./config/main.js') | |
1 | +config = require('../config/main.js') | |
2 | +fs = require('fs') | |
3 | +kue = require('kue') | |
4 | +queue = kue.createQueue() | |
5 | +exports = module.exports = {} | |
6 | + | |
7 | +# 1 - Core retornou um erro. | |
8 | +# 2 - Vídeo inválido. | |
9 | +# 3 - Legenda inválida. | |
10 | +# 4 - Endpoint inválido. | |
11 | + | |
12 | +# params_box = JSON.parse(fs.readFileSync('./config/params_box.json', 'utf8')) | |
13 | +# errors = JSON.parse(fs.readFileSync('./logsystem/errors.log', 'utf8')) | |
14 | +# services = JSON.parse(fs.readFileSync('./logsystem/services.log', 'utf8')) | |
15 | + | |
16 | + | |
17 | +writeLog = (file, path) -> | |
18 | + fs.writeFileSync path, JSON.stringify(file, null, 4) | |
19 | + | |
20 | + | |
21 | +exports.incrementError = (id, detalhe="", inc=1) -> | |
22 | + errors_log_path = "./logsystem/errors.log" | |
23 | + errors = JSON.parse(fs.readFileSync(errors_log_path, 'utf8')) | |
24 | + | |
25 | + bloqueante = !config.isNaoBloqueante() # diferente de nao bloqueante aceita bloqueante ou ambos | |
26 | + | |
27 | + # id pode ser "1", "2", "3", "4" ou qualquer outro id criado para identificar erros | |
28 | + # 1 - Core retornou um erro. | |
29 | + # 2 - Vídeo inválido. | |
30 | + # 3 - Legenda inválida. | |
31 | + # 4 - Endpoint inválido. | |
32 | + | |
33 | + if bloqueante | |
34 | + errors["resumo"]["bloqueante"][id] += inc | |
35 | + else | |
36 | + errors["resumo"]["nao-bloqueante"][id] += inc | |
37 | + | |
38 | + errors["detalhado"][id] = detalhe | |
39 | + | |
40 | + writeLog(errors, errors_log_path) | |
41 | + | |
42 | +exports.incrementService = (serviceType, type, inc=1) -> | |
43 | + services_log_path = "./logsystem/services.log" | |
44 | + services = JSON.parse(fs.readFileSync(services_log_path, 'utf8')) | |
45 | + | |
46 | + if serviceType == "videos" | |
47 | + services["tipo"]["videos"][type] += inc | |
48 | + else if serviceType == "outros" | |
49 | + services["tipo"]["outros"][type] += inc | |
50 | + | |
51 | + | |
52 | + writeLog(services, services_log_path) | |
53 | + | |
54 | +exports.updateHealth = (serviceType="outros", value=0) -> | |
55 | + services_log_path = "./logsystem/services.log" | |
56 | + services = JSON.parse(fs.readFileSync(services_log_path, 'utf8')) | |
57 | + | |
58 | + # if e else if pra excluir valores diferente desses dois | |
59 | + if serviceType == "videos" | |
60 | + services["tipo"]["videos"]["saude"] = value | |
61 | + else if serviceType == "outros" | |
62 | + services["tipo"]["outros"]["saude"] = value | |
63 | + | |
64 | + writeLog(services, services_log_path) | ... | ... |
logsystem/main.js
1 | 1 | (function() { |
2 | - var config; | |
2 | + var config, exports, fs, kue, queue, writeLog; | |
3 | 3 | |
4 | - config = require('./config/main.js'); | |
4 | + config = require('../config/main.js'); | |
5 | + | |
6 | + fs = require('fs'); | |
7 | + | |
8 | + kue = require('kue'); | |
9 | + | |
10 | + queue = kue.createQueue(); | |
11 | + | |
12 | + exports = module.exports = {}; | |
13 | + | |
14 | + writeLog = function(file, path) { | |
15 | + return fs.writeFileSync(path, JSON.stringify(file, null, 4)); | |
16 | + }; | |
17 | + | |
18 | + exports.incrementError = function(id, detalhe, inc) { | |
19 | + var bloqueante, errors, errors_log_path; | |
20 | + if (detalhe == null) { | |
21 | + detalhe = ""; | |
22 | + } | |
23 | + if (inc == null) { | |
24 | + inc = 1; | |
25 | + } | |
26 | + errors_log_path = "./logsystem/errors.log"; | |
27 | + errors = JSON.parse(fs.readFileSync(errors_log_path, 'utf8')); | |
28 | + bloqueante = !config.isNaoBloqueante(); | |
29 | + if (bloqueante) { | |
30 | + errors["resumo"]["bloqueante"][id] += inc; | |
31 | + } else { | |
32 | + errors["resumo"]["nao-bloqueante"][id] += inc; | |
33 | + } | |
34 | + errors["detalhado"][id] = detalhe; | |
35 | + return writeLog(errors, errors_log_path); | |
36 | + }; | |
37 | + | |
38 | + exports.incrementService = function(serviceType, type, inc) { | |
39 | + var services, services_log_path; | |
40 | + if (inc == null) { | |
41 | + inc = 1; | |
42 | + } | |
43 | + services_log_path = "./logsystem/services.log"; | |
44 | + services = JSON.parse(fs.readFileSync(services_log_path, 'utf8')); | |
45 | + if (serviceType === "videos") { | |
46 | + services["tipo"]["videos"][type] += inc; | |
47 | + } else if (serviceType === "outros") { | |
48 | + services["tipo"]["outros"][type] += inc; | |
49 | + } | |
50 | + return writeLog(services, services_log_path); | |
51 | + }; | |
52 | + | |
53 | + exports.updateHealth = function(serviceType, value) { | |
54 | + var services, services_log_path; | |
55 | + if (serviceType == null) { | |
56 | + serviceType = "outros"; | |
57 | + } | |
58 | + if (value == null) { | |
59 | + value = 0; | |
60 | + } | |
61 | + services_log_path = "./logsystem/services.log"; | |
62 | + services = JSON.parse(fs.readFileSync(services_log_path, 'utf8')); | |
63 | + if (serviceType === "videos") { | |
64 | + services["tipo"]["videos"]["saude"] = value; | |
65 | + } else if (serviceType === "outros") { | |
66 | + services["tipo"]["outros"]["saude"] = value; | |
67 | + } | |
68 | + return writeLog(services, services_log_path); | |
69 | + }; | |
5 | 70 | |
6 | 71 | }).call(this); | ... | ... |
package.json
server.js
... | ... | @@ -16,8 +16,10 @@ var app = express(); |
16 | 16 | var Request = require('./db/schemas/request').init(mongoose); |
17 | 17 | var db = require('./db/api'); |
18 | 18 | var config = require('./config/main.js'); |
19 | +var logger = require('./logsystem/main.js'); | |
19 | 20 | var kue = require('kue'); |
20 | 21 | var queue = kue.createQueue(); |
22 | +var unirest = require('unirest'); | |
21 | 23 | |
22 | 24 | app.use(express.static(path.join(__dirname, '/videos'))); |
23 | 25 | app.use(express.bodyParser({ keepExtensions: true, uploadDir: path.join(__dirname, '/uploads') })); |
... | ... | @@ -39,30 +41,37 @@ app.post('/api', function(req, res) { |
39 | 41 | switch(req.body.servico) { |
40 | 42 | /* Tipo de Serviço: Texto */ |
41 | 43 | case 'texto': |
44 | + logger.incrementService("outros", "requisicoes"); | |
42 | 45 | ep_texto.init(req, res, Request); |
43 | 46 | break; |
44 | 47 | |
45 | 48 | /* Tipo de Serviço: iOS */ |
46 | 49 | case 'ios': |
50 | + logger.incrementService("outros", "requisicoes"); | |
47 | 51 | ep_ios.init(req, res); |
48 | 52 | break; |
49 | 53 | |
50 | 54 | /* Tipo de Serviço: Só o Vídeo */ |
51 | 55 | case 'video': |
56 | + logger.incrementService("videos", "requisicoes"); | |
52 | 57 | ep_video.init(req, res); |
58 | + // logger.incrementService("videos", "traducoes"); | |
53 | 59 | break; |
54 | 60 | |
55 | 61 | case 'videornp': |
56 | 62 | ep_video_rnp.init(req, res, Request); |
57 | - break; | |
63 | + break; | |
58 | 64 | |
59 | 65 | /* Tipo de Serviço: Só a Legenda */ |
60 | 66 | case 'legenda': |
67 | + logger.incrementService("outros", "requisicoes"); | |
61 | 68 | ep_legenda.init(req, res); |
69 | + | |
62 | 70 | break; |
63 | 71 | |
64 | 72 | /* Tipo de Serviço: Video + Legenda */ |
65 | 73 | case 'video-legenda': |
74 | + logger.incrementService("outros", "requisicoes"); | |
66 | 75 | ep_video_legenda.init(req, res); |
67 | 76 | break; |
68 | 77 | |
... | ... | @@ -120,6 +129,14 @@ app.get('/glosa', function(req, res) { |
120 | 129 | }); |
121 | 130 | }); |
122 | 131 | |
132 | +// para testes apenas | |
133 | +app.get('/incrementaerro', function(req, res) { | |
134 | + // logger.incrementError("1", "detalhe do erro"); | |
135 | + // logger.incrementService("videos", "traducoes"); | |
136 | + res.send(200, "Incrementado"); | |
137 | + | |
138 | +}); | |
139 | + | |
123 | 140 | app.get('/limparfila', function(req, res) { |
124 | 141 | |
125 | 142 | // graceful shutdown |
... | ... | @@ -174,6 +191,30 @@ app.get('/limparfila', function(req, res) { |
174 | 191 | res.send(200, "Fila limpa"); |
175 | 192 | }); |
176 | 193 | |
194 | +// precisa ficar no final caso o request n bata com nenhuma rota anterior | |
195 | +app.get('/*', function(req, res){ | |
196 | + logger.incrementError("4", "Rota nao encontrada"); | |
197 | + res.send(404, { 'status': 'Rota nao encontrada' } ); | |
198 | +}); | |
199 | + | |
177 | 200 | app.listen(properties.port, properties.host, function(){ |
178 | 201 | console.log('Server running on ' + properties.host + ':' + properties.port); |
179 | 202 | }); |
203 | + | |
204 | + | |
205 | + | |
206 | +var CronJob = require('cron').CronJob; | |
207 | +// '* * * * * *' == a cada 1 segundo | |
208 | +new CronJob('* * * * * *', function() { | |
209 | + unirest.post('http://localhost:5000/api') | |
210 | + .header('Accept', 'application/json') | |
211 | + .send({ "servico": "texto", "transparencia": "opaco", "texto": "texto teste" }) | |
212 | + .end(function (response) { | |
213 | + console.log(response.status); | |
214 | + if(response.status === 200){ | |
215 | + logger.updateHealth("outros", 1); | |
216 | + } else { | |
217 | + logger.updateHealth(); | |
218 | + } | |
219 | + }); | |
220 | +}, null, true); // no lugar do null pode ser uma funcao pra executar quando parar | ... | ... |