Adding «DELETE» User Functionality
// 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');
this.bcrypt = require('bcryptjs');
}
async getAuthor(req, res){
const self = this;
const data = this.deepcopy(this.vdict);
data.site_title = 'ទំព័រអ្នកនិពន្ធ';
data.date = this.utility.setDate();
data.authors = await this.usersdb.selectUser(this.vdict.dashboardLimit);
data.thumbs = self.utility.getThumbUrl(data.authors, 'author');
data.count = await self.usersdb.countUser();
if(req.params.authorId){
data.edited = await self.usersdb.selectUser(self.vdict.dashboardLimit, req.params.authorId);
res.render('dashboard/author', data);
}else
res.render('dashboard/author', data);
}
async postAuthor(req, res){
const self = this;
const data = this.deepcopy(this.vdict);
data.site_title = 'ទំព័រអ្នកនិពន្ធ';
data.date = this.utility.setDate();
if(req.session.user.role == 'Admin'){
const user = await this.usersdb.checkEmail(req);
if(user){
data.authors = await self.usersdb.selectUser(self.vdict.dashboardLimit);
data.thumbs = self.utility.getThumbUrl(data.authors, 'author');
data.count = await self.usersdb.countUser();
data.message = 'Email នេះមានគេប្រើប្រាស់ហើយ';
res.render('dashboard/author', data);
}else{
self.emailCheck(req.body.email)
.then(async function (result) {
if(result){
const user = await self.usersdb.insertUser(req);
data.authors = await self.usersdb.selectUser(self.vdict.dashboardLimit);
data.thumbs = self.utility.getThumbUrl(data.authors, 'author');
data.count = await self.usersdb.countUser();
data.message = `អ្នកនិពន្ធ ${user.username} ត្រូវបានចុះបញ្ជីរួចហើយ`;
res.render('dashboard/author', data);
}
}).catch(async function (err) {
data.authors = await self.usersdb.selectUser(self.vdict.dashboardLimit);
data.thumbs = self.utility.getThumbUrl(data.authors, 'author');
data.count = await self.usersdb.countUser();
data.message = 'Email នេះមិនត្រឹមត្រូវទេ';
res.render('dashboard/author', data);
});
}
}else{
data.authors = await this.usersdb.selectUser(self.vdict.dashboardLimit);
data.thumbs = self.utility.getThumbUrl(data.authors, 'author');
data.count = await self.usersdb.countUser();
data.message = 'មានតែ Administrator ទេ ដែលអាចចុះបញ្ជីអ្នកនិពន្ធបាន';
res.render('dashboard/author', data);
}
}
async updateAuthor(req, res){
const self = this;
const data = this.deepcopy(this.vdict);
data.site_title = 'ទំព័រអ្នកនិពន្ធ';
data.date = this.utility.setDate();
if((req.session.user.role === "Admin") || (req.session.user.userid === req.params.authorId)){
const user = await this.usersdb.checkEmail(req);
if(user && (req.params.authorId != user.userid)){
data.authors = await self.usersdb.selectUser(self.vdict.dashboardLimit);
data.thumbs = self.utility.getThumbUrl(data.authors, 'author');
data.count = await self.usersdb.countUser();
data.message = 'Email នេះមានគេប្រើប្រាស់ហើយ';
res.render('dashboard/author', data);
}else{
self.emailCheck(req.body.email)
.then(async function (result) {
if(result){
if((req.session.user.role === "Admin") || (req.session.user.userid === user.userid)){
data.author = await self.usersdb.updateUser(req);
data.message = `ទិន្នន័យអ្នកនិពន្ធ ${data.author.username} ត្រូវបានកែតំរូវ`;
data.authors = await self.usersdb.selectUser(self.vdict.dashboardLimit);
data.thumbs = self.utility.getThumbUrl(data.authors, 'author');
data.count = await self.usersdb.countUser();
res.render('dashboard/author', data);
}
}
})
.catch(async function (err) {
data.authors = await self.usersdb.selectUser(self.vdict.dashboardLimit);
data.thumbs = self.utility.getThumbUrl(data.authors, 'author');
data.count = await self.usersdb.countUser();
data.message = 'Email នេះមិនត្រឹមត្រូវទេ';
res.render('dashboard/author', data);
});
}
}else{
data.authors = await this.usersdb.selectUser(self.vdict.dashboardLimit);
data.thumbs = self.utility.getThumbUrl(data.authors, 'author');
data.count = await self.usersdb.countUser();
data.message = 'មានតែ Administrator ឬសមីខ្លូនទេ ដែលអាចដូរទិន្នន័យអ្នកនិពន្ធបាន';
res.render('dashboard/author', data);
}
}
async deleteAuthor(req, res){
const self = this;
const data = this.deepcopy(this.vdict);
data.site_title = 'ទំព័រអ្នកនិពន្ធ';
data.date = this.utility.setDate();
if(req.session.user.role === "Admin"){
const user = await self.usersdb.deleteUser(req);
data.authors = await this.usersdb.selectUser(self.vdict.dashboardLimit);
data.thumbs = self.utility.getThumbUrl(data.authors, 'author');
data.count = await self.usersdb.countUser();
data.message = `អ្នកនិពន្ធឈ្មោះ ${user.username} ត្រូវបានលុបចេញពីបញ្ជី`;
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},
userid: {type: String, required: true},
password: {type: String, required: true},
email: {type: String, required: true},
role: {type: String, required: true},
info: {type: String, required: false},
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 id = (new Date()).getTime().toString(36) + Math.random().toString(36).slice(2);
const root = new users({userid:id, 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);
});
}
async checkEmail(req){
return await this.users.findOne({email:req.body.email});
}
async insertUser(req){
const hash = this.bcrypt.hashSync(req.body.password, 12);
const id = (new Date()).getTime().toString(36) + Math.random().toString(36).slice(2);
const user = new (this.users)({userid:id, username:req.body.username, password:hash, email:req.body.email, role:req.body.role, info:req.body.info, date: new Date(req.body.date)});
return await user.save();
}
async selectUser(amount=5, id=false){
if(id){
return await this.users.findOne({userid: id});
}else{
return await this.users.find().sort({date: -1, _id: -1}).limit(amount);
}
}
async countUser(){
return await this.users.countDocuments({});
}
async updateUser(req){
const user = await this.users.findOne({userid:req.params.authorId});
user.username = req.body.username;
user.email = req.body.email;
user.role = req.body.role;
user.info = req.body.info;
user.date = new Date(req.body.date);
if(req.body.password !== "oldpassword"){
const hash = this.bcrypt.hashSync(req.body.password, 12);
user.password = hash;
}
return await user.save();
}
async deleteUser(req){
const user = await this.users.findOne({userid:req.params.authorId});
await this.users.deleteOne({userid:user.userid});
return user;
}
}//end class
module.exports = new Usersdb();
GitHub: "https://github.com/Sokhavuth/multimedia
Heroku: https://khmerweb-multimedia.herokuapp.com/

Comments
Post a Comment