Adding «CREATE» User Functionality
// routes/admin.js
const express = require('express');
const router = express.Router();
const utility = require('../utility');
router.get('/', function(req, res, next){
if(req.session.user)
res.redirect('/admin/dashboard');
else
res.redirect('/admin/login');
});
router.get('/login', function(req, res, next){
const login = require('../controllers/login');
login.getLogin(res);
});
router.post('/login', function(req, res, next){
const login = require('../controllers/login');
login.postLogin(req, res);
});
router.get('/dashboard', function(req, res, next){
const index = require('../controllers/dashboard/index');
index.getIndex(req, res);
});
router.get('/logout', function(req, res, next){
if(req.session.user){
req.session.destroy(function (err) {
res.redirect('/');
});
}else{
res.redirect('/');
}
});
router.get('/author', function(req, res, next){
const author = require('../controllers/dashboard/author');
author.getAuthor(req, res);
});
router.post('/author', function(req, res, next){
const author = require('../controllers/dashboard/author')
author.postAuthor(req, res);
});
module.exports = router;
// controllers/dashboard/author.js
class Author{
constructor(){
this.deepcopy = require('deepcopy');
this.vdict = require('../../config');
this.utility = require('../../utility');
this.usersdb = require('../../models/usersdb');
this.emailCheck = require('email-check');
}
getAuthor(req, res){
if(req.session.user){
const data = this.deepcopy(this.vdict);
data.site_title = 'ទំព័រអ្នកនិពន្ធ';
data.date = this.utility.setDate();
res.render('dashboard/author', data);
}else{
res.redirect('/admin/login');
}
}
postAuthor(req, res){
const data = this.deepcopy(this.vdict);
data.site_title = 'ទំព័រអ្នកនិពន្ធ';
data.date = this.utility.setDate();
if(req.session.user.role == 'Admin'){
const self = this;
this.usersdb.checkEmail(req, function(user){
if(user){
data.message = 'Email នេះមានគេប្រើប្រាស់ហើយ';
res.render('dashboard/author', data);
}else{
self.emailCheck(req.body.email)
.then(function (result) {
if(result){
self.usersdb.insertUser(req, function(user, err){
if(!err)
data.message = `អ្នកនិពន្ធ ${user.username} ត្រូវបានចុះបញ្ជីរួចហើយ`;
else
data.message = err;
res.render('dashboard/author', data);
});
}
})
.catch(function (err) {
data.message = 'Email នេះមិនត្រឹមត្រូវទេ';
res.render('dashboard/author', data);
});
}
});
}else{
data.message = 'មានតែ Administrator ទេ ដែលអាចចុះបញ្ជីអ្នកនិពន្ធបាន';
res.render('dashboard/author', data);
}
}
}//end class
module.exports = new Author();
// models/usersdb.js
class Usersdb{
constructor(){
const mongoose = require('mongoose');
const bcrypt = require('bcryptjs');
const usersSchema = new mongoose.Schema({
username: {type: String, required: true},
password: {type: String, required: true},
email: {type: String, required: true},
role: {type: String, required: true},
info: {type: String, required: true},
date: {type: Date, required: true}
});
const users = mongoose.model('users', usersSchema);
this.users = users;
this.bcrypt = bcrypt;
users.findOne(function (err, user){
if (err) return console.error(err);
if(!user){
const hash = bcrypt.hashSync('password', 12);
const root = new users({username:'root', password:hash, email:'root@multimedia.com', role:'Admin', info:'test', date: new Date()});
root.save(function (err, root){
if (err) return console.error(err);
});
}
});
}
checkUser(req, callback){
this.users.findOne({email:req.body.email}, function (err, user){
if (err) return console.error(err);
return callback(user);
});
}
checkEmail(req, callback){
this.users.findOne({email:req.body.email}, function (err, user){
if (err) return console.error(err);
return callback(user);
});
}
insertUser(req, callback){
const hash = this.bcrypt.hashSync(req.body.password, 12);
const user = new (this.users)({username:req.body.username, password:hash, email:req.body.email, role:req.body.role, info:req.body.info, date: new Date(req.body.date)});
user.save(function (err, user){
if (err) return callback(false, err);
return callback(user, false)
});
}
}//end class
module.exports = new Usersdb();
GitHub: "https://github.com/Sokhavuth/multimedia
Heroku: https://khmerweb-multimedia.herokuapp.com/

Comments
Post a Comment