-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathapp.js
189 lines (154 loc) · 5.74 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
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
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
var express = require('express')
, expressValidator = require('express-validator')
, http = require('http')
, mongo = require('mongodb')
, mongoose = require('mongoose')
, mongoStore = require('connect-mongo')(express)
, path = require('path')
, flash = require('connect-flash') // flash message when redirect page
, nodemailer = require('nodemailer') // send mail
, MemoryStore = express.session.MemoryStore
, dbPath = 'mongodb://localhost/2dspot'
, events = require('events')
, fs = require('fs')
, passport = require('passport')
, util = require('util')
, LocalStrategy = require('passport-local').Strategy
, FacebookStrategy = require('passport-facebook').Strategy
, expressWinston = require('express-winston')
, winston = require('winston')
;
var app = express();
app.server = http.createServer(app); // Create an http server
app.sessionStore = new MemoryStore(); // Create a session store to share between methods
var logentries = require('node-logentries');
var log = logentries.logger({
token:'7cbb5061-0769-4718-bcb1-2af147f6fdcc'
});
var logStream = {
write: function(message,encoding) {
log.info(message.replace('\n', ''));
}
};
//Configurations
var config = {
domain: process.env.DOMAIN || 'http://inx.io',
redis : {
host: 'pub-redis-13685.us-east-1-2.2.ec2.garantiadata.com',
pass: '2dspot',
port: 13685
},
logFile: fs.createWriteStream('./myLogFile.log', {flags: 'a'}) //use {flags: 'w'} to open in write mode
/*
logger: new (winston.Logger)({
transports: [
new (winston.transports.Console)(),
new (winston.transports.File)({ filename: 'somefile.log' })
]
})*/
};
app.config = config;
app.ensureAuthenticated = function(req, res, next) {
if (req.isAuthenticated()) { return next(); }
res.status(403).send({'error':'unauthorized forbidden'})
};
app.configure(function(){
app.set('port', process.env.PORT || 3000);
app.set('views', __dirname + '/views');
app.use(express.static(path.join(__dirname, 'public')));
app.set('view engine', 'ejs');
app.use(express.favicon());
app.use(express.logger({
format: ':remote-addr ":method :url HTTP/:http-version" ":user-agent" :status :res[content-length] :response-time ms', //The format you prefer. This is optional. Not setting this will output the standard log format
stream: logStream //The variable we defined above. The stream method calls the write method.
}));
// app.use(expressWinston.logger({
// transports: [
// new winston.transports.Logio(),
// new (winston.transports.File)({ filename: 'somefile.log' })
// ]
// }));
app.use(express.bodyParser( {keepExtensions: true, uploadDir:'./public/images/uploads'} ));
app.use(express.methodOverride());
app.use(express.cookieParser());
//app.use(ga('MO-42439720-1',{
// safe: true
//}));
app.use(expressValidator);
app.use(express.session({
cookie: { maxAge: 2592000000 },
secret: 'keyboard cat 2dspot',
key: '2dspot.sid',
store: new mongoStore({ db: '2dspot' })
//store: app.sessionStore
}));
app.use(flash());
app.use(passport.initialize());
app.use(passport.session());
app.use(express.compress());
//app.use(app.router);
mongoose.connect(dbPath, function onMongooseError(err) {
if (err) throw err;
});
// mongoose.set('debug', true);
var db = mongoose.connection;
//db.on('error', console.error.bind(console, 'connection error:'));
db.once('open', function callback () {
console.log('Connected to DB');
});
});
app.configure('development', function(){
app.use(express.errorHandler());
});
// Model needs plugins
app.redis = require('./plugins/redis')(app, config, mongoose);
app.models = {}
app.models.Account = require('./models/Account')(app, config, mongoose, nodemailer);
app.models.Channel = require('./models/channel')(app, mongoose);
app.models.Post = require('./models/post')(app, mongoose)
app.models.Pin = require('./models/pin')(app, mongoose)
app.get('/', function(req, res){
res.render('index', { user: req.user });
});
app.get('/login', function(req, res){
res.render('login', { user: req.user, message: req.flash('error') });
});
app.get('/logout', function(req, res){
req.logout();
res.redirect('/');
});
require('./plugins/pass.js')(app,passport,LocalStrategy, app.models.Account);
require('./plugins/pass-facebook.js')(app, passport, FacebookStrategy, app.models.Account);
app.use(app.router)
var raven = require('raven');
var client = new raven.Client('https://916ecea72d7844c38a1aa6d3ba08e649:[email protected]/10745');
client.patchGlobal();
app.use(function(err, req, res, next){
// treat as 404
if (err.message
&& (~err.message.indexOf('not found')
|| (~err.message.indexOf('Cast to ObjectId failed')))) {
return next()
}
// log it
// send emails if you want
console.error(err.stack)
client.captureError(err)
// error page
res.status(500).render('500', { error: err.stack })
})
// assume 404 since no middleware responded
app.use(function(req, res, next){
res.status(404).send({'status':404})
})
module.exports = app;
if (!module.parent) {
http.createServer(app).listen(app.get('port'), function(){
console.log("Express server listening on port " + app.get('port'));
});
}
// Simple route middleware to ensure user is authenticated.
// Use this route middleware on any resource that needs to be protected. If
// the request is authenticated (typically via a persistent login session),
// the request will proceed. Otherwise, the user will be redirected to the
// login page.