-
Notifications
You must be signed in to change notification settings - Fork 7
/
app.js
107 lines (87 loc) · 2.04 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
var mongoose = require('mongoose')
, Schema = mongoose.Schema
, ObjectId = mongoose.SchemaTypes.ObjectId;
var conf = require('./config/oauth_providers');
var UserSchema = new Schema({
role : String
})
, User;
var mongooseAuth = require('mongoose-auth');
UserSchema.plugin(mongooseAuth, {
everymodule: {
everyauth: {
User: function() {
return User;
}
}
},
facebook: {
everyauth: {
myHostname: 'http://local.host:3000',
appId: conf.fb.appId,
appSecret: conf.fb.appSecret,
redirectPath: '/'
}
},
twitter: {
everyauth: {
myHostname: 'http://local.host:3000',
consumerKey: conf.twit.consumerKey,
consumerSecret: conf.twit.consumerSecret,
redirectPath: '/'
}
},
github: {
everyauth: {
myHostname: 'http://local.host:3000',
appId: conf.github.appId,
appSecret: conf.github.appSecret,
redirectPath: '/'
}
}
});
mongoose.model('User', UserSchema);
mongoose.connect('mongodb://localhost/example');
User = mongoose.model('User');
var express = require('express');
var app = express.createServer();
abilities = {
editor: {
index: ['read'],
protected: ['read']
},
default: {
index: ['read'],
// protected: ['read']
}
}
var ability = require('ability')();
ability.add(abilities);
ability.configure({
// whether or not to redirect
redirect: true,
// where to redirect
redirect_to: '/',
// the name of our everyauth role
role_name: 'role'
})
app.configure(function() {
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.bodyParser());
app.use(express.cookieParser());
app.use(express.session({secret: 'secret'}));
app.use(mongooseAuth.middleware());
});
app.dynamicHelpers({ messages: require('express-messages') });
ability.addHelpers(app);
mongooseAuth.helpExpress(app);
app.get('/', function(req, res){
authorize();
res.render('index');
});
app.get('/protected', function(req, res) {
authorize();
res.render('protected');
});
app.listen(3000);