-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp2.js
151 lines (118 loc) · 4.17 KB
/
app2.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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
var express = require('express');
var sessionExpress = require('express-session');
var sharedsession = require("express-socket.io-session");
var multer = require('multer');
var app = express();
var http = require('http');
var server = http.createServer(app);
var io = require('socket.io')(server);
var ipfilter = require('express-ipfilter');
var mongoStore = require('connect-mongo')(sessionExpress);
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var crypto = require('crypto');
var mongoose = require('mongoose');
mongoose.connect("mongodb://localhost/lit");
var routes = require('./routes/index');
var register = require('./routes/register');
var registerPost = require('./routes/registerPost');
var login = require('./routes/login');
var loginPost = require('./routes/loginPost');
var logout = require('./routes/logout');
var changePassword = require('./routes/settings/changePassword');
var changePasswordPost = require('./routes/settings/changePasswordPost');
var privilege = require('./routes/settings/privilege');
var privilegePost = require('./routes/settings/privilegePost');
var profilePic = require('./routes/settings/profilePic');
var profilePicPost = require('./routes/settings/profilePicPost');
var profileDesc = require('./routes/settings/profileDesc');
var profileDescPost = require('./routes/settings/profileDescPost');
var user = require('./routes/users');
var ips = [];
app.use(ipfilter(ips, {mode : 'allow', errorCode : 403, errorMessage : 'You\'ve been banned! Email us for help.'}));
function redirectSec(req, res, next) {
if (req.headers['x-forwarded-proto'] == 'http') {
res.redirect('https://' + req.headers.host + req.path);
} else {
return next();
}
}
var port = '3000';
app.set('port', port);
server.listen(port);
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'hjs');
// uncomment after placing your favicon in /public
//app.use(favicon(__dirname + '/public/favicon.ico'));
var session = sessionExpress({
secret: 'spaghetti',
store: new mongoStore({
db: 'litSessions',
host: 'localhost'
}),
saveUninitialized: true,
resave: true,
});
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser('spaghetti'));
app.use(session);
app.use(require('less-middleware')(path.join(__dirname, 'public')));
app.use(express.static(path.join(__dirname, 'public')));
app.enable('trust proxy');
app.use('/', routes);
app.use('/register', register);
app.use('/register/post', registerPost);
app.use('/login', login);
app.use('/login/post', loginPost);
app.use('/logout', logout);
app.use('/settings/changePassword', changePassword);
app.use('/settings/changePassword/post', changePasswordPost);
app.use('/settings/privilege', privilege);
app.use('/settings/privilege/post', privilegePost);
app.use('/settings/profilePic', profilePic);
app.use('/settings/profilePic/post', profilePicPost);
app.use('/settings/profileDesc', profileDesc);
app.use('/settings/profileDesc/post', profileDescPost);
//Socket Server
var io = require('socket.io')(server);
var p2p = require('socket.io-p2p-server').Server;
io.use(sharedsession(session));
io.on("connection", function(socket){
console.log(socket.handshake.session);
socket.on("room", function(data){
socket.join(data);
console.log("user joined room -> " + data);
});
socket.on('chatData', function(data){
data.username = socket.handshake.session.usernameAsTyped;
io.in(data.room).emit('chatData', data);
console.log(data);
});
socket.on('disconnect', function(){
delete socket;
})
});
// 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
// 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: err,
});
});
console.log("Running on port: " + port);
module.exports = app;