-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
94 lines (80 loc) · 3 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
var createError = require('http-errors');
var express = require('express');
var path = require('path');
var cookieParser = require('cookie-parser');
var logger = require('morgan');
var mongoose = require('mongoose');
var config = require('./config');
var bodyparser = require('body-parser');
var session = require('express-session');
// var OAuthServer = require('express-oauth-server');
// var models = require('./models/oauth');
var authorizeHandler = require('./middleware/authorizeHandler');
var oauth2server = require('./middleware/oauth2Server');
var app = express();
var router = express.Router();
//mongodb 数据库连接
mongoose.connect(config.get('mongoose:uri'),{useNewUrlParser:true,useCreateIndex:true});
mongoose.Promise = global.Promise;
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');
app.use(cookieParser());
app.use(bodyparser.json({ extended: false }));
app.use(bodyparser.urlencoded({ extended:false }));
app.use(express.static(path.join(__dirname, 'public')));
app.use(session({
secret:'sdfdasds-454-dfsadfa-sdfas',
saveUninitialized:false,
resave:true,
}));
// app.use('/', indexRouter);
// app.use('/users', usersRouter);
// catch 404 and forward to error handler
// app.use(function(req, res, next) {
// next(createError(404));
// });
// error handler
app.use(function(err, req, res, next) {
// set locals, only providing error in development
res.locals.message = err.message;
res.locals.error = req.app.get('env') === 'development' ? err : {};
// render the error page
res.status(err.status || 500);
res.render('error');
});
// TODO: /oauth/authorise /profile /register /login /
//07.10直接一上来就是authorize,不要什么applist了
app.use('/', router);
//Authorize part
router.route('/login').post(authorizeHandler.handleLogin,oauth2server.authorization);
router.route('/register').post(authorizeHandler.handleRegister,oauth2server.authorization);
router.route('/oauth/authorize')
.get(authorizeHandler.verifyAuthorizeQuery,oauth2server.authorization)
.post(oauth2server.authorize_pre,oauth2server.server.authorize({
authenticateHandler: {
handle: req => {
console.log('[authenticatehandler] get req.session.user:',req.session.user.userId);
return req.session.user;
}
}
}));
//Token part
router.route('/oauth/token').post(oauth2server.token_pre,oauth2server.server.token({ }));
// router.route('/oauth/token').post((req,res)=>{
// console.log('token req',req);
// });
//Authenticate part
router.route('/userinfo').get(oauth2server.server.authenticate({
}),oauth2server.userinfo);
// router.route('/userinfo').get((req,res)=>{
// console.log('info req',req);
// });
//07.24 logout测试
router.route('/oauth/logout').get(oauth2server.logout);
module.exports = app;
//nodemon 代码更改后自动refresh用
// app.set('port', process.env.PORT || 3000);
// var server = app.listen(app.get('port'), function() {
// console.log('Express server listening on port ' + server.address().port);
// });