-
Notifications
You must be signed in to change notification settings - Fork 5
/
app.js
76 lines (61 loc) · 1.83 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
var PORT = process.env.OPENSHIFT_NODEJS_PORT || 8080;
if (process.env.PHILLYHOODS_APP === 'development') {
var IP = '0.0.0.0';
} else {
var IP = process.env.OPENSHIFT_NODEJS_IP || "127.0.0.1";
require('strong-agent').profile(
process.env.NODEFLY,
'philly-hoods'
);
}
var restify = require('restify')
, locations = require('./routes/locations')
, neighborhoods = require('./routes/neighborhoods')
, invalid = require('./routes/invalid')
, bunyan = require('bunyan');
var logger = bunyan.createLogger({
name: 'philly-hoods',
streams: [
{
level: 'debug',
path: './logs/philly-hoods.log'
}
],
serializers: restify.bunyan.serializers,
});
var server = restify.createServer({
name: 'philly-hoods',
log: logger
});
server.use(restify.queryParser());
server.use(restify.jsonp());
server.use(restify.CORS());
server.use(restify.fullResponse());
server.use(restify.throttle({
rate: 3,
burst: 3,
ip: true
}));
server.get('/', function (req, res, next) { res.send(200, {application: 'Philly-Hoods', versions: ['v1'] }); });
server.get('/v1/', function (req, res, next) {
res.send(200, { application: 'Philly-Hoods',
version: '1',
endpoints: ['/neighborhoods', '/locations']
}
);
});
server.get('/v1/neighborhoods/', neighborhoods.list);
server.get('/v1/neighborhoods/:name', neighborhoods.get);
server.get(/^(\/v1\/locations\/)(\d+\.?(?=\d)\d*,-\d+\.?(?=\d)\d*$)/, locations.get);
server.get('/v1/locations/:coords', invalid.respond);
server.listen(PORT, IP, function () {
console.log('%s listening at %s', server.name, server.url);
logger.info('%s listening at %s', server.name, server.url);
});
server.pre(function (req, res, next) {
req.log.info({req: req}, 'start');
return next();
});
server.on('after', function (req, res, route) {
res.log.info({res: res}, 'finished');
});