-
Notifications
You must be signed in to change notification settings - Fork 4
/
app.js
92 lines (83 loc) · 2.66 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
88
89
90
91
92
// requires
var debug = require('debug')('roadgl'),
express = require('express'),
path = require('path'),
favicon = require('serve-favicon'),
logger = require('morgan'),
cookieParser = require('cookie-parser'),
bodyParser = require('body-parser'),
session = require('express-session'),
auth = require('./routes/auth'),
authrender = require('./routes/authrender'),
util = require('./routes/util'),
db = require('./routes/db'),
renderer = require('./routes/renderer'),
app = express()
// app setup
app.set('views', path.join(__dirname, 'views'))
app.set('view engine', 'jade')
app.use(favicon(__dirname + '/public/favicon.ico'))
app.use(logger('dev'))
app.use(bodyParser.json())
app.use(bodyParser.urlencoded({
extended: true
}))
app.use(cookieParser())
app.use(session({
secret: 'woah cat',
saveUninitialized: true,
resave: false
}))
app.use(express.static(path.join(__dirname, 'public'), {
maxAge: '1h' // caching
}))
app.use(util.initializeLocals)
db.initdb() // setup connection to the database
// Post routes
app.post('/save', auth.requiredAuthentication, db.saveEdit)
app.post('/autosave', auth.requiredAuthentication, db.autosaveEdit)
app.post('/categories', auth.requiredAuthentication, db.saveCategory)
app.post('/tags', auth.requiredAuthentication, db.saveTag)
app.post('/deleteTag', auth.requiredAuthentication, db.deleteTag)
// Get routes
app.get('/edit', auth.requiredAuthentication, renderer.edit)
app.get('/demo', renderer.guestEdit)
app.get('/browse', auth.requiredAuthentication, renderer.browse)
app.get('/tags', auth.requiredAuthentication, renderer.tag)
app.get('/', function (req, res) { res.redirect('/browse') })
// Authentication routes
app.post('/login', authrender.loginPost)
app.post('/logout', authrender.logoutPost)
app.post('/signup', auth.userExist, auth.signup)
app.get('/signup', authrender.signup)
app.get('/login', authrender.login)
// catch 404 and forward to error handler
app.use(function (req, res, next) {
var err = new Error('Not Found')
err.status = 404
next(err)
})
// error handlers
// development error handler will print stacktrace
if (app.get('env') === 'development') {
app.use(function (err, req, res, next) {
res.status(err.status || 500)
res.render('error', {
message: err.message,
error: err
})
})
}
// production error handler no stacktraces leaked to user
app.use(function (err, req, res, next) {
res.status(err.status || 500)
res.render('error', {
message: err.message,
error: {}
})
})
module.exports = app
app.set('port', process.env.PORT || 3000)
var server = app.listen(app.get('port'), function () {
debug('Express server listening on port ' + server.address().port)
})