This commit is contained in:
2020-05-03 18:22:51 -04:00
commit 8dc0e946b1
98 changed files with 19301 additions and 0 deletions

67
nodejs/routes/auth.js Executable file
View File

@ -0,0 +1,67 @@
'use strict';
const router = require('express').Router();
const {User} = require('../models/user');
const {Auth, AuthToken} = require('../models/auth');
router.post('/login', async function(req, res, next){
try{
let auth = await Auth.login(req.body);
return res.json({
login: true,
token: auth.token.token,
});
}catch(error){
next(error);
}
});
router.all('/logout', async function(req, res, next){
try{
if(req.user){
await req.user.logout();
}
res.json({message: 'Bye'})
}catch(error){
next(error);
}
});
router.post('/invite/:token', async function(req, res, next) {
try{
req.body.token = req.params.token;
let user = await User.addByInvite(req.body);
let token = await AuthToken.add(user);
return res.json({
user: user.username,
token: token.token
});
}catch(error){
next(error);
}
});
module.exports = router;
/*
verify public ssh key
*/
// router.post('/verifykey', async function(req, res){
// let key = req.body.key;
// try{
// return res.json({
// info: await Users.verifyKey(key)
// });
// }catch(error){
// return res.status(400).json({
// message: 'Key is not a public key file!'
// });
// }
// });

26
nodejs/routes/group.js Normal file
View File

@ -0,0 +1,26 @@
'use strict';
const router = require('express').Router();
const {Group} = require('../models/group_ldap');
router.get('/', async function(req, res, next){
try{
return res.json({
results: await Group[req.query.detail ? "listDetail" : "list"]()
});
}catch(error){
next(error);
}
});
router.get('/:name', async function(req, res, next){
try{
return res.json({
results: await Group.get(req.params.name)
});
}catch(error){
next(error);
}
});
module.exports = router;

35
nodejs/routes/index.js Executable file
View File

@ -0,0 +1,35 @@
var express = require('express');
var router = express.Router();
const {InviteToken} = require('./../models/token');
/* GET home page. */
router.get('/', async function(req, res, next) {
res.render('home', { title: 'Express' });
});
/* GET home page. */
router.get('/users', function(req, res, next) {
res.render('users', { title: 'Express' });
});
router.get('/login/invite/:token', async function(req, res, next){
try{
console.log('token', req.params.token)
let token = await InviteToken.get(req.params.token);
console.log('invite', token);
if(token.is_valid){
res.render('invite', { title: 'Express', invite: token });
}else{
next({status: 404});
}
}catch(error){
next(error);
}
});
/* GET home page. */
router.get('/login', function(req, res, next) {
res.render('login', {redirect: req.query.redirect});
});
module.exports = router;

63
nodejs/routes/token.js Normal file
View File

@ -0,0 +1,63 @@
'use strict';
const router = require('express').Router();
const {AuthToken} = require('../models/auth');
const {Token, InviteToken} = require('../models/token');
const tokens = {
auth: AuthToken,
invite: InviteToken
}
router.get('/:name', async function(req, res, next){
try{
console.log(tokens, req.params.name)
return res.json({
results: await tokens[req.params.name][req.query.detail ? "listDetail" : "list"]()
});
}catch(error){
next(error);
}
});
router.get('/:name/:token', async function(req, res, next){
try{
return res.json({
results: await tokens[req.params.name].get(req.params.token)
});
}catch(error){
next(error);
}
});
// router.delete('/:username', async function(req, res, next){
// try{
// let user = await User.get(req.params.username);
// return res.json({username: req.params.username, results: await user.remove()})
// }catch(error){
// next(error);
// }
// });
module.exports = router;
/*
verify public ssh key
*/
// router.post('/verifykey', async function(req, res){
// let key = req.body.key;
// try{
// return res.json({
// info: await Users.verifyKey(key)
// });
// }catch(error){
// return res.status(400).json({
// message: 'Key is not a public key file!'
// });
// }
// });

89
nodejs/routes/user.js Executable file
View File

@ -0,0 +1,89 @@
'use strict';
const router = require('express').Router();
const {User} = require('../models/user');
router.get('/', async function(req, res, next){
try{
return res.json({
results: await User[req.query.detail ? "listDetail" : "list"]()
});
}catch(error){
next(error);
}
});
router.post('/', async function(req, res, next){
try{
req.body.created_by = req.user.username
return res.json({results: await User.add(req.body)});
}catch(error){
next(error);
}
});
router.delete('/:username', async function(req, res, next){
try{
let user = await User.get(req.params.username);
return res.json({username: req.params.username, results: await user.remove()})
}catch(error){
next(error);
}
});
router.get('/me', async function(req, res, next){
try{
return res.json(await User.get({username: req.user.username}));
}catch(error){
next(error);
}
});
router.put('/password', async function(req, res, next){
try{
return res.json({results: await req.user.setPassword(req.body)})
}catch(error){
next(error);
}
});
router.put('/password/:username', async function(req, res, next){
try{
let user = await User.get(req.params.username);
return res.json({results: await user.setPassword(req.body)});
}catch(error){
next(error);
}
});
router.post('/invite', async function(req, res, next){
try{
let token = await req.user.invite();
return res.json({token: token.token});
}catch(error){
next(error);
}
});
router.post('/key', async function(req, res, next){
try{
let added = await User.addSSHkey({
username: req.user.username,
key: req.body.key
});
return res.status(added === true ? 200 : 400).json({
message: added
});
}catch(error){
next(error);
}
});
module.exports = router;