-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwebsite.js
117 lines (101 loc) · 3.54 KB
/
website.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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
require('app-module-path').addPath(__dirname);
const express = require('express')
const markoExpress = require('marko/express')
const pjson = require('./package.json')
const config = require(__dirname + '/config.js')
const mongoose = require("mongoose")
const session = require("express-session")
const MongoStore = require("connect-mongo")(session)
const compression = require("compression")
const bodyParser = require("body-parser")
const cookieParser = require("cookie-parser")
const csrf = require("csurf")
const http = require("http")
const passport = require("passport")
const multer = require('multer')
// var https = require('https');
// var forceSSL = require('express-force-ssl');
require("marko/node-require").install()
require("marko/browser-refresh").enable()
require("lasso/browser-refresh").enable("*.marko *.css *.less")
require("lasso").configure({
plugins: [
"lasso-less",
"lasso-marko"
],
bundlingEnabled: config.production, // Only enable bundling in production
cacheProfile: config.production ? "production" : "development",
fingerprintsEnabled: true, // Only add fingerprints to URLs in production, actually needs to be enabled for lasso-less to work properly
minify: config.production, //Don't minify for now, otherwise too verbose in console // Only minify JS and CSS code in production
outputDir: __dirname + "/static" // Place all generated JS/CSS/etc. files into the "static" dir
})
function setupApp() {
var app = express()
app.use(markoExpress())
app.use(require("lasso/middleware").serveStatic())
app.use(cookieParser())
app.use(bodyParser.json())
app.use(bodyParser.urlencoded({extended: true}))
app.use(csrf({cookie: true}))
app.use(compression())
//app.use(forceSSL); //TODO enable for production
var storage = multer.memoryStorage()
var upload = multer({
storage : storage
})
mongoose.Promise = global.Promise
mongoose.connect("mongodb://" + config.db.username + ":" + config.db.password + "@" + config.db.host + ":" + config.db.port + "/" + config.db.name,
{ useMongoClient: true },
function(error) {
if(error) {
console.log(error)
process.exit(1)
}
else {
console.log("Connection to the database successful.")
}
}
)
var store = new MongoStore ({
mongooseConnection: mongoose.connection,
collection: "sessions",
touchAfter: 24 * 3600 // time period in seconds
})
store.on("error", function(error) {
assert.ifError(error)
assert.ok(false)
})
app.use(session ({
secret: config.cookieSecret,
cookie: {
maxAge: 1000 * 60 * 60 * 24 * 7 // 1 week
},
store: store,
saveUninitialized: false, // don't create session until something stored
resave: true // don't save session if unmodified
}))
app.use(passport.initialize())
app.use(passport.session())
require("./src/controllers/passport")(passport)
app.use(require("./src/controllers/")(app, express, passport, upload))
return app
}
var app = setupApp()
var server = http.createServer(app)
server.listen(config.server.port,function() {
console.log("Website server v%s listening at https://%s:%s", pjson.version, config.server.address, config.server.port)
if (process.send) {
process.send("online")
}
})
/*var sslOptions = {
key: fs.readFileSync("certificates/client-key.pem"),
cert: fs.readFileSync("certificates/client-cert.pem")
}*/
/*var secureServer = https.createServer(sslOptions, app);
secureServer.listen(443, function() {
console.log("Andre Silva Santos server v%s listening at https://%s:%s", pjson.version, config.server.address, config.server.port)
if (process.send) {
process.send('online');
}
})*/