forked from Nekos-moe/api
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
79 lines (67 loc) · 2.57 KB
/
server.js
File metadata and controls
79 lines (67 loc) · 2.57 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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
const express = require('express'),
app = express(),
bodyParser = require('body-parser'),
morgan = require('morgan'),
toml = require('toml'),
fs = require('fs'),
settings = toml.parse(fs.readFileSync('./settings.toml')),
Database = require('./structures/Database'),
mailTransport = require('./structures/mailTransport'),
webhookTransport = require('./structures/webhookTransport'),
db = new Database(settings.mongo),
raven = require('raven');
mailTransport.config({ from: settings.email.from, test: settings.email.test });
webhookTransport.config(settings.webhooks);
if (process.env.NODE_ENV === 'production') {
raven.disableConsoleAlerts();
raven.config(settings.raven.url, {
release: (require('./package.json')).version,
autoBreadcrumbs: { 'http': true },
captureUnhandledRejections: true
}).install();
app.use(raven.requestHandler());
app.use(raven.errorHandler());
global.statsd = new (require("node-dogstatsd")).StatsD(settings.statsd.host, settings.statsd.port);
var datadog = require('connect-datadog')({
dogstatsd: statsd,
tags: ['app:catgirls-api'],
response_code: true,
path: true,
method: true
});
app.use(datadog);
} else {
global.statsd = new Proxy({ }, {
get() { return function() { } }
});
}
app.set('trust proxy', 'loopback');
app.set('env', 'production');
app.disable('x-powered-by');
app.use(morgan(':req[cf-connecting-ip] :method :url :status :response-time[0]ms', {
skip: (req, res) => res.statusCode < 400 // Only log failed requests/responses
}));
// Parse data into req.body
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
// In dev we need a way to get images
if (process.env.NODE_ENV === 'development') {
app.use('/image', express.static('image', { index: false, extensions: ['jpg'] }));
app.use('/thumbnail', express.static('thumbnail', { index: false, extensions: ['jpg'] }));
}
app.use((req, res, next) => {
res.set('Access-Control-Allow-Origin', '*');
res.set('Access-Control-Allow-Credentials', 'true');
res.set('Access-Control-Allow-Methods', 'GET,OPTIONS,POST,PUT,PATCH,DELETE');
res.set('Access-Control-Allow-Headers', 'Access-Control-Allow-Headers, Origin, Accept, X-Requested-With, Content-Type, Access-Control-Request-Method, Access-Control-Request-Headers, Authorization');
return next();
});
// Load in the routes for express
let apiv1 = new (require('./api/v1/Router.js'))(settings, db, mailTransport, webhookTransport);
app.use(apiv1.path, apiv1.router);
// Start the express server
app.listen(settings.port, error => {
if (error)
return console.log(error)
console.log('Server online');
});