mirror of
https://github.com/Foltik/Shimapan
synced 2025-01-05 15:58:03 -05:00
Add invite codes for registering
This commit is contained in:
parent
8251900309
commit
e6a09bbe40
17
app/models/Invite.js
Normal file
17
app/models/Invite.js
Normal file
@ -0,0 +1,17 @@
|
||||
var mongoose = require('mongoose');
|
||||
|
||||
var InviteSchema = mongoose.Schema({
|
||||
code: {
|
||||
type: String,
|
||||
unique: true,
|
||||
required: true
|
||||
},
|
||||
level: Number,
|
||||
issuer: String,
|
||||
recipient: String,
|
||||
issued: Date,
|
||||
used: Date,
|
||||
exp: Date
|
||||
});
|
||||
|
||||
module.exports = mongoose.model('Invite', InviteSchema);
|
@ -18,7 +18,8 @@ var UserSchema = mongoose.Schema({
|
||||
},
|
||||
level: Number,
|
||||
hash: String,
|
||||
salt: String
|
||||
salt: String,
|
||||
date: Date
|
||||
});
|
||||
|
||||
UserSchema.methods.setPassword = function(password) {
|
||||
|
@ -5,28 +5,64 @@ var express = require('express');
|
||||
var router = express.Router();
|
||||
|
||||
var mongoose = require('mongoose');
|
||||
var User = mongoose.model('User');
|
||||
var User = require('../models/User.js');
|
||||
var Invite = require('../models/Invite.js');
|
||||
|
||||
var passport = require('passport');
|
||||
|
||||
router.post('/register', function(req, res) {
|
||||
console.log(req.body);
|
||||
|
||||
var user = new User();
|
||||
user.username = req.body.username;
|
||||
user.level = 0;
|
||||
user.genApiKey();
|
||||
user.setPassword(req.body.password);
|
||||
|
||||
user.save(function(err) {
|
||||
var token;
|
||||
token = user.genJwt();
|
||||
res.status(200);
|
||||
res.json({
|
||||
"token": token
|
||||
});
|
||||
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);
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
router.post('/register', function(req, res) {
|
||||
// Check the username
|
||||
validUsername(req.body.username, function(err, valid) {
|
||||
if (!valid) {
|
||||
res.status(401).json({'message': 'Username in use.'});
|
||||
return;
|
||||
}
|
||||
|
||||
// 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;
|
||||
}
|
||||
|
||||
var user = new User();
|
||||
user.username = req.body.username;
|
||||
user.level = invite.level;
|
||||
user.date = Date.now();
|
||||
user.genApiKey();
|
||||
user.setPassword(req.body.password);
|
||||
|
||||
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});
|
||||
}
|
||||
})
|
||||
})
|
||||
});
|
||||
});
|
||||
|
||||
router.post('/login', function(req, res) {
|
||||
@ -39,10 +75,7 @@ router.post('/login', function(req, res) {
|
||||
var token;
|
||||
if (user) {
|
||||
token = user.genJwt();
|
||||
res.status(200);
|
||||
res.json({
|
||||
"token": token
|
||||
});
|
||||
res.status(200).json({'token': token });
|
||||
} else {
|
||||
res.status(401).json(info);
|
||||
}
|
||||
|
@ -2,7 +2,8 @@ function RegisterController($scope, AuthService) {
|
||||
$scope.register = function() {
|
||||
AuthService.register({
|
||||
username: $scope.username,
|
||||
password: $scope.password
|
||||
password: $scope.password,
|
||||
invite: $scope.invite
|
||||
}).then(function() {
|
||||
alert('Registered');
|
||||
});
|
||||
|
@ -7,5 +7,9 @@
|
||||
<label for="password">Password</label>
|
||||
<input id="password" class="form-control" type="password" ng-model="password"/>
|
||||
</div>
|
||||
<div class="form-group">
|
||||
<label for="invite">Invite Code</label>
|
||||
<input id="invite" class="form-control" type="text" ng-model="invite"/>
|
||||
</div>
|
||||
<button type="submit" class="btn">Register</button>
|
||||
</form>
|
@ -16,7 +16,7 @@
|
||||
<script src="/js/app.js"></script>
|
||||
</head>
|
||||
<body ng-app="shimapan">
|
||||
<div id="container" ng-controller="RegisterController">
|
||||
<div id="container">
|
||||
<register-component></register-component>
|
||||
</div>
|
||||
</body>
|
||||
|
Loading…
Reference in New Issue
Block a user