2018-12-08 19:21:48 +01:00
|
|
|
const express = require('express');
|
|
|
|
const router = express.Router();
|
|
|
|
const Models = require('../../models');
|
|
|
|
const bCrypt = require('bcrypt-nodejs');
|
2018-10-31 17:00:31 +01:00
|
|
|
//--------------------------
|
|
|
|
// Index
|
|
|
|
//--------------------------
|
2019-02-27 17:17:51 +01:00
|
|
|
router.get('/', function(req, res) {
|
|
|
|
var loggedIn = false;
|
|
|
|
if (req.session.user) loggedIn = true;
|
|
|
|
Models.FreshPost.findAll({
|
|
|
|
order: [['id', 'DESC']]
|
|
|
|
})
|
|
|
|
.then(function(posts) {
|
2019-02-27 22:09:39 +01:00
|
|
|
let title = 'Fipamo Dashboard';
|
|
|
|
let welcome = '';
|
|
|
|
!loggedIn
|
2019-02-27 17:17:51 +01:00
|
|
|
? (welcome = 'Hello.')
|
|
|
|
: (welcome = 'Welcome back, ' + req.session.user.handle);
|
|
|
|
let filtered = [];
|
|
|
|
for (let index = 0; index < posts.length; index++) {
|
|
|
|
let item = posts[index].post;
|
|
|
|
if (typeof item.deleted == 'undefined' || item.deleted == false) {
|
|
|
|
filtered.push(posts[index]);
|
|
|
|
} else {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
res.render('dash/index', {
|
|
|
|
title: title,
|
|
|
|
welcome: welcome,
|
|
|
|
user_status: loggedIn,
|
|
|
|
items: filtered
|
|
|
|
});
|
|
|
|
})
|
|
|
|
.then(() => {
|
|
|
|
//console.log(value);
|
|
|
|
})
|
|
|
|
.catch(() => {
|
|
|
|
//next(err);
|
|
|
|
});
|
2018-10-31 17:00:31 +01:00
|
|
|
});
|
|
|
|
//--------------------------
|
2018-12-08 19:21:48 +01:00
|
|
|
// Login
|
2018-10-31 17:00:31 +01:00
|
|
|
//--------------------------
|
2018-12-08 19:21:48 +01:00
|
|
|
/* Handle Login POST */
|
2019-02-27 17:17:51 +01:00
|
|
|
router.post('/login', function(req, res) {
|
|
|
|
Models.User.findOne({
|
|
|
|
where: {
|
|
|
|
handle: req.body.handle
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.then(user => {
|
|
|
|
if (!isValidPassword(user, req.body.password)) {
|
|
|
|
return res.json({
|
|
|
|
message: 'CHECK YOUR PASSWORD'
|
|
|
|
});
|
|
|
|
}
|
|
|
|
let session = req.session;
|
|
|
|
session.user = user;
|
|
|
|
res.redirect('/@/dashboard');
|
|
|
|
})
|
|
|
|
.catch(() => {
|
|
|
|
return res.json({
|
|
|
|
message: 'NOT FOUND, HAWS'
|
|
|
|
});
|
|
|
|
});
|
2018-10-31 17:00:31 +01:00
|
|
|
});
|
|
|
|
//--------------------------
|
2018-12-08 19:21:48 +01:00
|
|
|
// Logout
|
2018-10-31 17:00:31 +01:00
|
|
|
//--------------------------
|
2019-02-27 17:17:51 +01:00
|
|
|
router.post('/logout', function(req, res) {
|
|
|
|
req.logout();
|
|
|
|
return res.json({
|
|
|
|
message: 'LOGGED OUT'
|
|
|
|
});
|
2018-10-31 17:00:31 +01:00
|
|
|
});
|
2018-12-08 19:21:48 +01:00
|
|
|
module.exports = router;
|
2019-02-27 17:17:51 +01:00
|
|
|
var isValidPassword = function(user, password) {
|
|
|
|
return bCrypt.compareSync(password, user.password);
|
|
|
|
};
|