forked from thesentinelproject/threatwiki_node
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
136 lines (123 loc) · 4.78 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
var application_root = __dirname
, routes = require("./routes")
, model = require("./model")
, express = require("express")
, everyauth = require('everyauth')
, mongoose = require('mongoose')
, path = require("path")
, util = require('util')
// api
, soc_api = require("./api/soc_api")
, datapoint_api = require("./api/datapoint_api")
, tag_api = require("./api/tag_api")
//, user_api = require("./api/user_api")
;
var app = module.exports = express.createServer();
app.enable("jsonp callback");
everyauth.helpExpress(app);
// database
mongoose.connect('mongodb://localhost/namp', function(err) {
if (err) throw err;
});
//This is our mongohq database config, already created, we can switch to this webcentered database whenever we want
//mongoose.connect('mongodb://nodejitsu:[email protected]:10058/nodejitsudb795685203760', function(err) {
//if (err) throw err;
//});
// create model
var createModel = model.createModel();
var SocModel = model.SocModel;
var DataPointModel = model.DataPointModel;
var TagModel = model.TagModel;
var UserModel = model.UserModel;
//using the informations we get back from Google Apps, we check if we already have this user in the DB,
//if yes we return it, if not we create a new one
function addOrGetUser (sourceUser) {
return UserModel.findOne({ email: sourceUser.email}, function (err, user){
if (!err && user) {
console.log("Found the user in DB with email: "+sourceUser.email);
return user;
} else if (!user) {
console.log("Did not find the user in DB with email: "+sourceUser.email+" , creating new user in DB");
//Did not find a user, create a new one
user = new UserModel({
name: sourceUser.name,
email: sourceUser.email,
created : Date.now(),
modified: Date.now()
});
user.save(function (err) {
if (!err) {
return console.log("user created");
} else {
return console.log(err);
}
});
} else {
return console.log(err);
}
});
}
everyauth.google
.appId('619120872838.apps.googleusercontent.com')
.appSecret('aAE27lzFLKQi9QX-lFfToDbk')
.scope('https://www.googleapis.com/auth/userinfo.email https://www.googleapis.com/auth/userinfo.profile') // What you want access to
//TODO: redirect to our own auth-fail page
// .handleAuthCallbackError( function (req, res) {
//})
.findOrCreateUser( function (session, accessToken, accessTokenExtra, googleUserMetadata) {
//only allow someone to login with an email that finish by thesentinelproject.org
var splitemail = googleUserMetadata.email.split("@");
var domain = splitemail[1];
if (domain=='thesentinelproject.org'){
googleUserMetadata.refreshToken = accessTokenExtra.refresh_token;
googleUserMetadata.expiresIn = accessTokenExtra.expires_in;
console.log(util.inspect(googleUserMetadata));
return (addOrGetUser(googleUserMetadata));
} else {
console.log("Not the sentinel project domain name");
return ['Not the sentinel project domain name'];
}
})
.redirectPath('/soc'); //where to redirect after we get back from the login screen from google
// config
app.configure(function () {
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.bodyParser());
app.use(express.cookieParser());
//TODO: Will need to specify a memorystore to go in PROD (see warning in log when deploying in PROD)
app.use(express.session({ 'secret' : 'not sure what to put here' }));
app.use(everyauth.middleware());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(__dirname + '/public'));
});
app.configure('development', function(){
app.use(express.errorHandler({ dumpExceptions: true, showStack: true }));
});
app.configure('production', function(){
app.use(express.errorHandler());
});
// helpers
app.helpers({
});
// get routes
app.get('/', routes.index);
app.get('/soc', routes.soc);
app.get('/soc/create', routes.soc.create);
app.get('/soc/edit', routes.soc.edit);
app.get('/datapoint', routes.datapoint);
app.get('/datapoint/create', routes.datapoint.create);
app.get('/datapoint/edit', routes.datapoint.edit);
app.get('/tag', routes.tag);
app.get('/tag/create', routes.tag.create);
app.get('/tag/edit', routes.tag.edit);
// import socApi
var socApi = soc_api.load_socApi(app, SocModel,UserModel);
var datapointApi = datapoint_api.load_datapointApi(app, DataPointModel, TagModel, UserModel);
var tagApi = tag_api.load_tagApi(app, TagModel, DataPointModel,UserModel);
//var userApi = user_api.load_userApi(app, UserModel);
// server listen
app.listen(3000);
//console.log("server's up at %d in %s mode", app.address().port, app.settings.env);
console.log("server's up in %s mode", app.settings.env);