2020-03-21 21:22:12 +00:00
|
|
|
require('dotenv').config();
|
2019-12-11 00:07:07 +00:00
|
|
|
const express = require('express');
|
|
|
|
const bodyParser = require('body-parser');
|
|
|
|
const session = require('express-session');
|
|
|
|
const path = require('path');
|
|
|
|
const helmet = require('helmet');
|
2020-02-17 16:49:59 +00:00
|
|
|
const cors = require('cors');
|
2019-12-11 00:07:07 +00:00
|
|
|
|
|
|
|
const db = require('./server/lib/loginmanager');
|
|
|
|
|
2020-03-21 21:22:12 +00:00
|
|
|
const doJob = require('./server/lib/job');
|
|
|
|
const checkAuth = require('./server/middle/checkAuth');
|
|
|
|
|
2019-12-11 00:07:07 +00:00
|
|
|
// create express app
|
|
|
|
const app = express();
|
|
|
|
require('dotenv').config();
|
|
|
|
|
|
|
|
const serverPort = process.env.PORT || 3000;
|
|
|
|
|
2020-02-17 16:49:59 +00:00
|
|
|
const sitePath = 'dist';
|
2019-12-11 00:07:07 +00:00
|
|
|
|
2020-02-17 16:49:59 +00:00
|
|
|
app.use(cors());
|
2019-12-11 00:07:07 +00:00
|
|
|
app.use(helmet());
|
|
|
|
|
|
|
|
app.use(session({
|
|
|
|
'secret': 'rBLH5#Q89Z4',
|
|
|
|
'resave': true,
|
|
|
|
'saveUninitialized': true
|
|
|
|
}));
|
|
|
|
|
2020-03-21 21:22:12 +00:00
|
|
|
app.get('/', (request, response) => {
|
|
|
|
if (request.session.auth)
|
|
|
|
response.redirect('/menu');
|
|
|
|
else
|
|
|
|
response.sendFile(path.join(`${__dirname}/server/static/login.html`));
|
|
|
|
});
|
|
|
|
|
|
|
|
app.get('/menu', checkAuth, (req, res) => {
|
|
|
|
res.sendFile(path.join(`${__dirname }/dist/index.html`));
|
2019-12-11 00:07:07 +00:00
|
|
|
});
|
2020-03-21 21:22:12 +00:00
|
|
|
|
2019-12-11 00:07:07 +00:00
|
|
|
app.use(express.static(path.join(__dirname, sitePath)));
|
|
|
|
|
|
|
|
// parse requests of content-type - application/x-www-form-urlencoded
|
|
|
|
app.use(bodyParser.urlencoded({ 'extended': true }));
|
|
|
|
|
|
|
|
// parse requests of content-type - application/json
|
|
|
|
app.use(bodyParser.json());
|
|
|
|
|
2020-03-21 21:22:12 +00:00
|
|
|
app.post('/auth', (request, response) => {
|
2019-12-11 00:07:07 +00:00
|
|
|
const username = request.body.u;
|
|
|
|
const password = request.body.p;
|
|
|
|
|
|
|
|
if (username && password)
|
|
|
|
|
|
|
|
db.getOne(username, password)
|
|
|
|
.then((data) => {
|
|
|
|
if (!data)
|
2020-03-21 21:22:12 +00:00
|
|
|
// response.send('Incorrect Username and/or Password!');
|
|
|
|
response.redirect('/');
|
2019-12-11 00:07:07 +00:00
|
|
|
else {
|
|
|
|
request.session.username = username;
|
2020-03-21 21:22:12 +00:00
|
|
|
request.session.auth = 'jhgkjgkjhgkjhgjkhgjkhgfhghfjgfjhgf';
|
|
|
|
response.redirect('/menu');
|
2019-12-11 00:07:07 +00:00
|
|
|
}
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
console.log(err);
|
|
|
|
response.status(500).send({
|
|
|
|
'message': err.message || 'Some error occurred while querying the database.'
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
else {
|
2019-12-11 00:21:59 +00:00
|
|
|
response.send('Please enter Username and Password!');
|
|
|
|
response.end();
|
|
|
|
}
|
2019-12-11 00:07:07 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
require('./server/routes/recipe.routes')(app);
|
|
|
|
require('./server/routes/view.routes')(app);
|
|
|
|
|
|
|
|
// listen for requests
|
|
|
|
app.listen(serverPort, () => {
|
2019-12-11 00:21:59 +00:00
|
|
|
console.log(`Server is listening on port ${serverPort}`);
|
2019-12-11 00:07:07 +00:00
|
|
|
});
|
2020-03-21 21:22:12 +00:00
|
|
|
|
|
|
|
((() => {
|
|
|
|
console.log('Menuizer started');
|
|
|
|
// doJob();
|
|
|
|
})());
|