1
0
mirror of https://github.com/Foltik/Shimapan synced 2024-09-21 11:11:22 -04:00
shimapan/app/routes/auth.js

85 lines
2.4 KiB
JavaScript
Raw Normal View History

2017-10-11 10:15:19 -04:00
var fs = require('fs');
var path = require('path');
var express = require('express');
var router = express.Router();
var mongoose = require('mongoose');
2017-10-11 12:55:46 -04:00
var User = require('../models/User.js');
var Invite = require('../models/Invite.js');
2017-10-11 10:15:19 -04:00
var passport = require('passport');
2017-10-11 12:55:46 -04:00
function validUsername(username, callback) {
User.find({username: username}).limit(1).count(function(err, count) {
if (err) return callback(err);
count === 0 ? callback(null, true) : callback(null, false);
});
}
function useInvite(code, user, callback) {
Invite.findOne({code: code}, function(err, invite) {
if (err) return callback(err);
if (!invite || invite.used) {
return callback(null, false, null);
} else {
Invite.updateOne({code: code}, {recipient: user, used: Date.now()}, function(err, res) {
if (err) throw err;
});
callback(null, true, invite);
}
})
}
2017-10-11 10:15:19 -04:00
router.post('/register', function(req, res) {
2017-10-11 12:55:46 -04:00
// Check the username
validUsername(req.body.username, function(err, valid) {
if (!valid) {
res.status(401).json({'message': 'Username in use.'});
return;
}
2017-10-11 10:15:19 -04:00
2017-10-11 12:55:46 -04:00
// Check and use the invite
useInvite(req.body.invite, req.body.username, function(err, valid, invite) {
if (!valid) {
res.status(401).json({'message': 'Invalid invite code.'});
return;
}
2017-10-11 10:15:19 -04:00
2017-10-11 12:55:46 -04:00
var user = new User();
user.username = req.body.username;
2017-10-11 20:26:07 -04:00
user.scope = invite.scope;
2017-10-11 12:55:46 -04:00
user.date = Date.now();
user.setPassword(req.body.password);
2017-10-11 10:15:19 -04:00
2017-10-11 12:55:46 -04:00
user.save(function(err) {
if (err) {
res.status(500).json({'message': 'Internal server error'});
} else {
var token = user.genJwt();
res.status(200).json({'token': token});
}
})
})
});
2017-10-11 10:15:19 -04:00
});
router.post('/login', function(req, res) {
passport.authenticate('local', function(err, user, info) {
if (err) {
res.status(404).json(err);
return;
}
var token;
if (user) {
token = user.genJwt();
2017-10-11 12:55:46 -04:00
res.status(200).json({'token': token });
2017-10-11 10:15:19 -04:00
} else {
res.status(401).json(info);
}
})(req, res);
});
module.exports = router;