-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathapp.js
87 lines (79 loc) · 2.26 KB
/
app.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
/**
* Copyright carclub.lipengbo.com
* Author: [email protected]
*/
//region requirejs
var requirejs = require('requirejs');
requirejs.config({
nodeRequire: require
});
//endregion
requirejs([
'http',
'config',
'./server/logger',
'express',
'ejs',
'compression',
//'serve-favicon',
'morgan',
'serve-static',
'errorhandler',
'body-parser',
'mongoose',
'server/api/index',
'server/weixin/index'
], function (http, config, logger, express, ejs, compress, morgan, serveStatic, errorhandler, bodyParser, mongoose, apiRoutes, weixinRoutes) {
'use strict';
//region http server
try {
//region database
mongoose.connect(config.db.ConnectString);
logger.info('DB: connect to ' + config.db.ConnectString);
//endregion
//region express
var app = express();
var server = http.Server(app);
// app.use(compress());
app.use(bodyParser.json());
// app.use(methodOverride());
//endregion
//region development log
if (process.env.NODE_ENV === 'development') {
app.use(morgan('short'));
}
//endregion
//region routes
apiRoutes(app);
weixinRoutes(app);
//endregion
//region static and favicon
if (process.env.NODE_ENV === 'development') {
app.use(serveStatic(__dirname + '/client'));
} else {
app.use(serveStatic(__dirname + '/client-build'));
}
//endregion
//region error handler
app.use(function (err, req, res, next) {
if (err) {
logger.error('app.errorHandler---->' + res.req.method + ' ' + res.req.url);
logger.error('app.errorHandler---->err:' + JSON.stringify(err));
}
next();
});
app.use(errorhandler());
//endregion
//region port
var port = process.env.PORT || 3030; //for heroku
// var port = 18080; //for BAE
server.listen(port, function () {
logger.info('app---->Http server listening on port ' + port);
});
//endregion
} catch (err) {
logger.error('app---->err:' + JSON.stringify(err));
} finally {
}
//endregion
});