-
Notifications
You must be signed in to change notification settings - Fork 0
/
server.js
91 lines (79 loc) · 2.7 KB
/
server.js
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
/**
* Copyright (c) 2015-present, Alejandro Mantilla <@AlejoJamC>.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree or translated in the assets folder.
*/
/**
* Required modules
*/
var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var methodOverride = require('method-override');
var session = require('express-session');
var bodyParser = require('body-parser');
// TODO: arreglar la carga de archivos con multer [1]
//var multer = require('multer');
var errorHandler = require('errorhandler');
var moment = require('moment');
var routes = require('./routes/routes');
// TODO: traducir los comentarios a ingles
//Crea variable ambiente
var ambiente = "devLocal";
// Asigna el modulo a la variable configuracion
var configuracion = require('./config/environment.json')[ambiente];
// Configuramos variables globales
global.BEARERTOKEN = configuracion.bearer;
global.WEBSERVICE = configuracion.webservice;
//Asigna el puerto de la configuracion --Entorno local
var puerto = process.env.PORT || configuracion.port;
// Declara la nueva aplicacion de express
var app = express();
// app.locals variables
app.locals.currentYear = moment().year();
// Se cargan las configuraciones y los paquetes para esta nueva app de express
// Puerto
app.set('port', puerto);
// Configurar vista (Views) y el template engine
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');
// Ubicacion del Favicon
app.use(favicon(__dirname + '/public/favicon.ico'));
// Logger de Express
app.use(logger('dev'));
// Permitir utilizar verbos HTTP en todos los clientes
app.use(methodOverride());
// Sesiones
app.use(session({
resave: true,
saveUninitialized: true,
secret: '3f1l 4 73g 0t d33n yll43r u s1ht d43r n4c u f1' }));
// Parser del contenido en el body
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
// TODO: arreglar la carga de archivos con multer [2]
// Manejador de multipart/form-data para cargar archivos
//app.use(multer());
// Importando arhivos estaticos
app.use(express.static(path.join(__dirname, 'public')));
// Variables locales
// Año actual
app.locals.currentYear = moment().year();
// Utiliza el metodo AgregarRutas
routes.agregarRutas(app);
/// Manejador de 404
app.use(function(req, res, next) {
var err = new Error('Not Found');
err.status = 404;
next(err);
});
var env = process.env.NODE_ENV || ambiente;
if ('devLocal' == env){
app.use(errorHandler());
}
app.listen(app.get('port'), function(){
console.log("AVARITIA Back-Office listening on port " + puerto);
});