auth, first setup, error handling, small fixes

This commit is contained in:
Ivan 2023-09-11 12:57:10 +03:00
parent 97554fc6bb
commit 3262ae0230
Signed by untrusted user who does not match committer: ppechenkoo
GPG Key ID: 0C191B86D9582583
19 changed files with 727 additions and 653 deletions

649
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -14,6 +14,7 @@
"body-parser": "^1.20.2", "body-parser": "^1.20.2",
"dotenv": "^16.3.1", "dotenv": "^16.3.1",
"express": "^4.18.2", "express": "^4.18.2",
"express-session": "^1.17.3",
"fs": "^0.0.1-security", "fs": "^0.0.1-security",
"handlebars": "^4.7.7", "handlebars": "^4.7.7",
"http": "^0.0.1-security", "http": "^0.0.1-security",

458
server.js
View File

@ -13,6 +13,7 @@ const moment = require('moment');
const bodyParser = require('body-parser'); const bodyParser = require('body-parser');
const _ = require('lodash'); const _ = require('lodash');
const puppeteer = require('puppeteer'); const puppeteer = require('puppeteer');
const session = require('express-session');
const storage = multer.diskStorage({ const storage = multer.diskStorage({
@ -25,13 +26,22 @@ const storage = multer.diskStorage({
}); });
const upload = multer({ storage: storage }); const upload = multer({ storage: storage });
app.use(
session({
secret: process.env.SSH_PORT,
resave: false,
saveUninitialized: true,
cookie: { maxAge: 24 * 60 * 60 * 1000 },
})
);
app.use(express.static(path.join(__dirname, "static"))); app.use(express.static(path.join(__dirname, "static")));
app.use(express.json()); app.use(express.json());
app.use(express.urlencoded({ extended: false })); app.use(express.urlencoded({ extended: false }));
app.use(bodyParser.json()); app.use(bodyParser.json());
app.get("/", index); app.get("/", index);
app.get("/login", login); app.get("/signin", signin);
app.get("/register", register); app.get("/register", register);
app.get("/live", live); app.get("/live", live);
app.get("/reports", reports); app.get("/reports", reports);
@ -54,7 +64,62 @@ const commandToExecute = 'docker ps | grep connectionserver-video-server';
const conn = new Client(); const conn = new Client();
async function getUserInfo(userId) {
const pool = new Pool({
user: DB_User,
host: DB_Host,
database: DB_Name,
password: DB_Password,
port: DB_Port,
});
const client = await pool.connect();
try {
let userInfo = {
Organisation: "",
User: '',
Users: [],
};
if (userId != "admin") {
const queryUsers = `
SELECT name, surname, devices, edittransport, deletetransport, update
FROM users
WHERE id = $1
`;
const usersResult = await client.query(queryUsers, [userId]);
const user = usersResult.rows[0];
userInfo.Users.push({
name: user.name,
surname: user.surname,
devices: user.devices,
edittransport: user.edittransport,
deletetransport: user.deletetransport,
update: user.update,
});
userInfo.User = user.name + " " + user.surname;
} else {
userInfo.User = "Администратор"
}
const queryMain = `SELECT organisation FROM main`;
const mainResult = await client.query(queryMain);
userInfo.Organisation = mainResult.rows[0].organisation;
return userInfo;
} catch (error) {
console.error(error);
throw error;
} finally {
client.release();
}
}
app.post("/videos/restart", async (req, res) => { app.post("/videos/restart", async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
conn.on('ready', function() { conn.on('ready', function() {
console.log('Подключение по SSH успешно'); console.log('Подключение по SSH успешно');
@ -118,9 +183,15 @@ const DB_Port = "5432";
const DB_Name = "postgres"; const DB_Name = "postgres";
async function index(req, res) { async function index(req, res) {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const userInfo = await getUserInfo(req.session.userId);
var templateData = { var templateData = {
Organisation: "Название организации", Organisation: userInfo.Organisation,
User: "Тестовое Имя", User: userInfo.User,
UserInfo: userInfo.Users,
isAdmin: req.session.userId === 'admin',
ifDBError: false, ifDBError: false,
Count: "", Count: "",
AlarmsLast11Days: new Array(11).fill(0), AlarmsLast11Days: new Array(11).fill(0),
@ -264,17 +335,163 @@ for (let i = 0; i < dates.length; i++) {
} }
} }
function login(req, res) { function signin(req, res) {
res.sendFile(path.join(__dirname, "static/templates/login.html")); if (req.session.userId != undefined) {
return res.redirect("/");
} }
function register(req, res) { const pool = new Pool({
res.sendFile(path.join(__dirname, "static/templates/register.html")); user: DB_User,
host: DB_Host,
database: DB_Name,
password: DB_Password,
port: DB_Port,
});
pool.query('SELECT COUNT(*) FROM main', (error, result) => {
if (error) {
console.error('Ошибка при выполнении запроса к базе данных:', error);
res.status(500).send('Ошибка сервера');
return;
} }
const rowCount = parseInt(result.rows[0].count, 10);
if (rowCount === 0) {
res.redirect('/register');
} else {
res.sendFile(path.join(__dirname, 'static/templates/signin.html'));
}
});
}
function register(req, res) {
if (req.session.userId != undefined) {
return res.redirect("/");
}
const pool = new Pool({
user: DB_User,
host: DB_Host,
database: DB_Name,
password: DB_Password,
port: DB_Port,
});
pool.query('SELECT COUNT(*) FROM main', (err, result) => {
if (err) {
console.error('Ошибка выполнения SQL-запроса:', err);
res.status(500).send('Внутренняя ошибка сервера');
return;
}
if (result.rows[0].count > 0) {
res.redirect('/signin');
} else {
res.sendFile(path.join(__dirname, 'static/templates/register.html'));
}
});
}
app.post('/setup', async (req, res) => {
if (req.session.userId != undefined) {
return res.redirect("/");
}
try {
const pool = new Pool({
user: DB_User,
host: DB_Host,
database: DB_Name,
password: DB_Password,
port: DB_Port,
});
const { name, login, password } = req.body;
const checkQuery = 'SELECT * FROM main LIMIT 1';
const checkResult = await pool.query(checkQuery);
if (checkResult.rows.length > 0) {
res.redirect('/signin');
}
const insertQuery = 'INSERT INTO main (organisation, login, password) VALUES ($1, $2, $3)';
await pool.query(insertQuery, [name, login, password]);
res.status(200).json({ message: 'Данные успешно добавлены' });
} catch (error) {
console.error('Ошибка при обработке запроса:', error);
res.status(500).json({ error: 'Произошла ошибка при обработке запроса' });
}
});
app.post('/login', async (req, res) => {
if (req.session.userId != undefined) {
return res.redirect("/");
}
const { email, password } = req.body;
try {
const pool = new Pool({
user: DB_User,
host: DB_Host,
database: DB_Name,
password: DB_Password,
port: DB_Port,
});
const mainQuery = await pool.query(
'SELECT * FROM main WHERE login = $1 AND password = $2',
[email, password]
);
const mainUser = mainQuery.rows[0];
if (mainUser) {
req.session.userId = "admin";
console.log("Авторизация успешна (из таблицы main)");
return res.status(200).json({ message: 'Авторизация успешна' });
}
const userQuery = await pool.query(
'SELECT id, name, surname FROM users WHERE email = $1 AND password = $2',
[email, password]
);
const user = userQuery.rows[0];
if (!user) {
return res.status(401).json({ message: 'Неправильное имя пользователя или пароль' });
}
req.session.userId = user.id;
console.log("Авторизация успешна (из таблицы users)");
res.status(200).json({ message: 'Авторизация успешна' });
} catch (error) {
console.error('Ошибка при выполнении запроса к базе данных:', error);
res.status(500).json({ message: 'Ошибка сервера' });
}
});
app.get('/logout', (req, res) => {
req.session.destroy((err) => {
if (err) {
console.error('Ошибка при выходе из системы:', err);
res.status(500).json({ message: 'Ошибка сервера' });
} else {
res.redirect('/signin');
}
});
});
async function live(req, res) { async function live(req, res) {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const userInfo = await getUserInfo(req.session.userId);
let templateData = { let templateData = {
Organisation: "Название организации", Organisation: userInfo.Organisation,
User: "Тестовое Имя", User: userInfo.User,
UserInfo: userInfo.Users,
isAdmin: req.session.userId === 'admin',
ifDBError: false, ifDBError: false,
Registrars: [], Registrars: [],
Alarms: [], Alarms: [],
@ -512,6 +729,9 @@ async function live(req, res) {
} }
app.post("/devices-geo", async (req, res) => { app.post("/devices-geo", async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const selectedDevices = req.body.devices; const selectedDevices = req.body.devices;
const pool = new Pool({ const pool = new Pool({
@ -575,9 +795,15 @@ pool.query(subquery, selectedDevices, (err, result) => {
async function reports(req, res) { async function reports(req, res) {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const userInfo = await getUserInfo(req.session.userId);
let templateData = { let templateData = {
Organisation: "Название организации", Organisation: userInfo.Organisation,
User: "Тестовое Имя", User: userInfo.User,
UserInfo: userInfo.Users,
isAdmin: req.session.userId === 'admin',
ifDBError: false, ifDBError: false,
Registrars: [], Registrars: [],
Groups: [], Groups: [],
@ -790,6 +1016,9 @@ async function reports(req, res) {
} }
app.get("/api/devices", async (req, res) => { app.get("/api/devices", async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
try { try {
const pool = new Pool({ const pool = new Pool({
user: DB_User, user: DB_User,
@ -912,11 +1141,17 @@ async function generatePDF(data) {
app.get('/reports/:id', async (req, res) => { app.get('/reports/:id', async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const userInfo = await getUserInfo(req.session.userId);
const id = req.params.id; const id = req.params.id;
let templateData = { let templateData = {
Organisation: "Название организации", Organisation: userInfo.Organisation,
User: "Тестовое Имя", User: userInfo.User,
UserInfo: userInfo.Users,
isAdmin: req.session.userId === 'admin',
ifDBError: false, ifDBError: false,
Id: id, Id: id,
Type: "", Type: "",
@ -1199,11 +1434,17 @@ app.get('/reports/:id', async (req, res) => {
}); });
app.get('/generate-pdf/:id', async (req, res) => { app.get('/generate-pdf/:id', async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const userInfo = await getUserInfo(req.session.userId);
const id = req.params.id; const id = req.params.id;
let templateData = { let templateData = {
Organisation: "Название организации", Organisation: userInfo.Organisation,
User: "Тестовое Имя", User: userInfo.User,
UserInfo: userInfo.Users,
isAdmin: req.session.userId === 'admin',
ifDBError: false, ifDBError: false,
Id: id, Id: id,
Type: "", Type: "",
@ -1463,9 +1704,15 @@ let data = {
}); });
async function devices(req, res) { async function devices(req, res) {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const userInfo = await getUserInfo(req.session.userId);
let templateData = { let templateData = {
Organisation: "Название организации", Organisation: userInfo.Organisation,
User: "Тестовое Имя", User: userInfo.User,
UserInfo: userInfo.Users,
isAdmin: req.session.userId === 'admin',
ifDBError: false, ifDBError: false,
Registrars: [], Registrars: [],
Groups: [], Groups: [],
@ -1570,6 +1817,9 @@ async function getParameterByName(serial, fieldName) {
} }
app.post('/device-parameters', async (req, res) => { app.post('/device-parameters', async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
try { try {
const { serial, FIELDS } = req.body; const { serial, FIELDS } = req.body;
// console.log(serial, FIELDS); // console.log(serial, FIELDS);
@ -1615,6 +1865,9 @@ function findPathForField(fieldName) {
} }
app.put('/device-parameters', async (req, res) => { app.put('/device-parameters', async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
// Получаем данные из PUT запроса // Получаем данные из PUT запроса
const requestData = req.body; const requestData = req.body;
const { serial } = req.query; const { serial } = req.query;
@ -1673,6 +1926,9 @@ app.put('/device-parameters', async (req, res) => {
app.post("/devicedata", async (req, res) => { app.post("/devicedata", async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const id = req.body.id; const id = req.body.id;
const pool = new Pool({ const pool = new Pool({
@ -1696,6 +1952,9 @@ app.post("/devicedata", async (req, res) => {
}); });
app.post("/updatedevice", async (req, res) => { app.post("/updatedevice", async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const pool = new Pool({ const pool = new Pool({
user: DB_User, user: DB_User,
host: DB_Host, host: DB_Host,
@ -1827,6 +2086,9 @@ app.post("/updatedevice", async (req, res) => {
}); });
app.post("/updatedriver", upload.single("upload-file"), async (req, res) => { app.post("/updatedriver", upload.single("upload-file"), async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const pool = new Pool({ const pool = new Pool({
user: DB_User, user: DB_User,
host: DB_Host, host: DB_Host,
@ -1897,6 +2159,9 @@ app.post("/updatedriver", upload.single("upload-file"), async (req, res) => {
}); });
app.post("/adddriver", upload.single("upload-file"), async (req, res) => { app.post("/adddriver", upload.single("upload-file"), async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const pool = new Pool({ const pool = new Pool({
user: DB_User, user: DB_User,
host: DB_Host, host: DB_Host,
@ -1966,6 +2231,9 @@ app.post("/adddriver", upload.single("upload-file"), async (req, res) => {
}); });
app.post("/driverdata", async (req, res) => { app.post("/driverdata", async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const id = req.body.id; const id = req.body.id;
const pool = new Pool({ const pool = new Pool({
@ -1991,6 +2259,9 @@ app.post("/driverdata", async (req, res) => {
}); });
app.post("/userdata", async (req, res) => { app.post("/userdata", async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const id = req.body.id; const id = req.body.id;
const pool = new Pool({ const pool = new Pool({
@ -2016,6 +2287,9 @@ app.post("/userdata", async (req, res) => {
}); });
app.post("/deletedriver", async (req, res) => { app.post("/deletedriver", async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const id = req.body.id; const id = req.body.id;
const pool = new Pool({ const pool = new Pool({
@ -2040,6 +2314,9 @@ app.post("/deletedriver", async (req, res) => {
}); });
app.post("/deleteuser", async (req, res) => { app.post("/deleteuser", async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const id = req.body.id; const id = req.body.id;
const pool = new Pool({ const pool = new Pool({
@ -2064,9 +2341,15 @@ app.post("/deleteuser", async (req, res) => {
}); });
async function drivers(req, res) { async function drivers(req, res) {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const userInfo = await getUserInfo(req.session.userId);
let templateData = { let templateData = {
Organisation: "Название организации", Organisation: userInfo.Organisation,
User: "Тестовое Имя", User: userInfo.User,
UserInfo: userInfo.Users,
isAdmin: req.session.userId === 'admin',
ifDBError: false, ifDBError: false,
Drivers: [], Drivers: [],
Registrars: [], Registrars: [],
@ -2136,20 +2419,85 @@ async function drivers(req, res) {
} }
} }
function update(req, res) { async function update(req, res) {
res.sendFile(path.join(__dirname, "static/templates/devices/update.html")); if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const userInfo = await getUserInfo(req.session.userId);
let templateData = {
Organisation: userInfo.Organisation,
User: userInfo.User,
ifDBError: false,
UserInfo: userInfo.Users,
isAdmin: req.session.userId === 'admin',
};
try {
const source = fs.readFileSync("static/templates/devices/update.html", "utf8");
const template = handlebars.compile(source);
const resultT = template(templateData);
res.send(resultT);
} catch (error) {
console.error(error);
templateData.ifDBError = true;
const source = fs.readFileSync(
"static/templates/devices/update.html",
"utf8"
);
const template = handlebars.compile(source);
const resultT = template(templateData);
res.send(resultT);
}
} }
function settings(req, res) { async function settings(req, res) {
res.sendFile(path.join(__dirname, "static/templates/settings.html")); if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const userInfo = await getUserInfo(req.session.userId);
let templateData = {
Organisation: userInfo.Organisation,
User: userInfo.User,
ifDBError: false,
UserInfo: userInfo.Users,
isAdmin: req.session.userId === 'admin',
};
try {
const source = fs.readFileSync("static/templates/settings.html", "utf8");
const template = handlebars.compile(source);
const resultT = template(templateData);
res.send(resultT);
} catch (error) {
console.error(error);
templateData.ifDBError = true;
const source = fs.readFileSync(
"static/templates/settings.html",
"utf8"
);
const template = handlebars.compile(source);
const resultT = template(templateData);
res.send(resultT);
}
} }
async function adminPanel(req, res) { async function adminPanel(req, res) {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
if (req.session.userId != "admin") {
return res.redirect("/signin");
}
const userInfo = await getUserInfo(req.session.userId);
let templateData = { let templateData = {
Organisation: "Название организации", Organisation: userInfo.Organisation,
User: "Тестовое Имя", User: userInfo.User,
ifDBError: false, ifDBError: false,
Users: [], Users: [],
UserInfo: userInfo.Users,
isAdmin: req.session.userId === 'admin',
}; };
try { try {
@ -2208,6 +2556,12 @@ async function adminPanel(req, res) {
// Обработка POST-запроса для добавления пользователя // Обработка POST-запроса для добавления пользователя
app.post("/add-user", async (req, res) => { app.post("/add-user", async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
if (req.session.userId != "admin") {
return res.redirect("/signin");
}
const { name, surname, email, phone, password } = req.body; const { name, surname, email, phone, password } = req.body;
console.log(name, surname, email, phone, password) console.log(name, surname, email, phone, password)
@ -2244,11 +2598,20 @@ app.post("/add-user", async (req, res) => {
}); });
app.get('/admin/user/:id', async (req, res) => { app.get('/admin/user/:id', async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
if (req.session.userId != "admin") {
return res.redirect("/signin");
}
const userInfo = await getUserInfo(req.session.userId);
const id = req.params.id; const id = req.params.id;
let templateData = { let templateData = {
Organisation: "Название организации", Organisation: userInfo.Organisation,
User: "Тестовое Имя", User: userInfo.User,
UserInfo: userInfo.Users,
isAdmin: req.session.userId === 'admin',
ifDBError: false, ifDBError: false,
Id: id, Id: id,
Name: "", Name: "",
@ -2344,6 +2707,12 @@ app.get('/admin/user/:id', async (req, res) => {
}); });
app.post("/updateuser/:id", async (req, res) => { app.post("/updateuser/:id", async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
if (req.session.userId != "admin") {
return res.redirect("/signin");
}
const id = req.params.id; const id = req.params.id;
const pool = new Pool({ const pool = new Pool({
user: DB_User, user: DB_User,
@ -2413,9 +2782,15 @@ app.post("/updateuser/:id", async (req, res) => {
}); });
async function videos(req, res) { async function videos(req, res) {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const userInfo = await getUserInfo(req.session.userId);
let templateData = { let templateData = {
Organisation: "Название организации", Organisation: userInfo.Organisation,
User: "Тестовое Имя", User: userInfo.User,
UserInfo: userInfo.Users,
isAdmin: req.session.userId === 'admin',
ifDBError: false, ifDBError: false,
Registrars: [], Registrars: [],
Groups: [], Groups: [],
@ -2501,9 +2876,15 @@ async function videos(req, res) {
} }
async function videoExport(req, res) { async function videoExport(req, res) {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const userInfo = await getUserInfo(req.session.userId);
let templateData = { let templateData = {
Organisation: "Название организации", Organisation: userInfo.Organisation,
User: "Тестовое Имя", User: userInfo.User,
UserInfo: userInfo.Users,
isAdmin: req.session.userId === 'admin',
ifDBError: false, ifDBError: false,
Registrars: [], Registrars: [],
Groups: [], Groups: [],
@ -2590,6 +2971,9 @@ async function videoExport(req, res) {
} }
app.get('/getData', async (req, res) => { app.get('/getData', async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const selectedSerial = req.query.serial; const selectedSerial = req.query.serial;
const selectedDate = req.query.selectedDate; const selectedDate = req.query.selectedDate;
const selectedTime = req.query.selectedTime; const selectedTime = req.query.selectedTime;
@ -2657,6 +3041,9 @@ app.get('/getData', async (req, res) => {
}); });
app.post("/getspeedarchive", async (req, res) => { app.post("/getspeedarchive", async (req, res) => {
if (req.session.userId === undefined) {
return res.redirect("/signin");
}
const { serial, datetime } = req.body; const { serial, datetime } = req.body;
const formattedDateTime = new Date(datetime).toISOString(); const formattedDateTime = new Date(datetime).toISOString();
@ -2709,6 +3096,9 @@ app.listen(port, () => {
console.log(`Server is running on port ${port}`); console.log(`Server is running on port ${port}`);
}); });
// app.use((req, res, next) => { app.use((req, res, next) => {
// res.sendFile(path.join(__dirname, "static/templates/404.html")); if (req.session.userId === undefined) {
// }); return res.redirect("/signin");
}
res.sendFile(path.join(__dirname, "static/templates/404.html"));
});

25
static/templates/404.html Normal file
View File

@ -0,0 +1,25 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Здесь ничего нет</title>
<link rel="stylesheet" href="../styles/main.css" />
</head>
<body>
<section class="form right">
<form>
<h1 style="margin-bottom: 40px;">Здесь ничего нет...</h1>
<button onclick="location.href = '/';" type="button">Вернуться</button>
</form>
</section>
<video class="animation left" autoplay muted loop>
<source src="../img/traffic.mp4" type="video/mp4">
</video>
<span class="copyright left"><a href="https://dribbble.com/shots/15608015-Traffic">Видеоматериал создан Igor Kozak для 10Clouds</a></span>
</body>
</html>

View File

@ -21,7 +21,7 @@
<img id="down" src="../img/down.svg"> <img id="down" src="../img/down.svg">
<img id="up" src="../img/up.svg"> <img id="up" src="../img/up.svg">
</div> </div>
<a href="/login"><div id="account-additional" class="additional">Выйти</div></a> <a href="/logout"><div id="account-additional" class="additional">Выйти</div></a>
</section> </section>

View File

@ -21,7 +21,7 @@
<img id="down" src="../../img/down.svg"> <img id="down" src="../../img/down.svg">
<img id="up" src="../../img/up.svg"> <img id="up" src="../../img/up.svg">
</div> </div>
<a href="/login"><div id="account-additional" class="additional">Выйти</div></a> <a href="/logout"><div id="account-additional" class="additional">Выйти</div></a>
</section> </section>

View File

@ -11,17 +11,17 @@
<header> <header>
<h1>Аргус</h1> <h1>Аргус</h1>
<h2><span>/</span> Название организации</h2> <h2><span>/</span> {{Organisation}}</h2>
</header> </header>
<section class="account-info"> <section class="account-info">
<div id="account-main"> <div id="account-main">
<img id="person" src="../img/person.svg"> <img id="person" src="../img/person.svg">
<span>Тестовое Имя</span> <span>{{User}}</span>
<img id="down" src="../img/down.svg"> <img id="down" src="../img/down.svg">
<img id="up" src="../img/up.svg"> <img id="up" src="../img/up.svg">
</div> </div>
<a href="/login"><div id="account-additional" class="additional">Выйти</div></a> <a href="/logout"><div id="account-additional" class="additional">Выйти</div></a>
</section> </section>
@ -43,6 +43,11 @@
<a href="/videos"> <a href="/videos">
<div><img src="../img/play.svg">Записи</div> <div><img src="../img/play.svg">Записи</div>
</a> </a>
{{#if isAdmin}}
<a class="admin-panel" href="/admin">
<div><img src="../img/keyboard.svg">Админка</div>
</a>
{{/if}}
<a class="settings" href="/settings"> <a class="settings" href="/settings">
<div><img src="../img/gear.svg">Настройки</div> <div><img src="../img/gear.svg">Настройки</div>
</a> </a>

View File

@ -11,17 +11,17 @@
<header> <header>
<h1>Аргус</h1> <h1>Аргус</h1>
<h2><span>/</span> Название организации</h2> <h2><span>/</span> {{Organisation}}</h2>
</header> </header>
<section class="account-info"> <section class="account-info">
<div id="account-main"> <div id="account-main">
<img id="person" src="../img/person.svg"> <img id="person" src="../img/person.svg">
<span>Тестовое Имя</span> <span>{{User}}</span>
<img id="down" src="../img/down.svg"> <img id="down" src="../img/down.svg">
<img id="up" src="../img/up.svg"> <img id="up" src="../img/up.svg">
</div> </div>
<a href="/login"><div id="account-additional" class="additional">Выйти</div></a> <a href="/logout"><div id="account-additional" class="additional">Выйти</div></a>
</section> </section>
@ -43,6 +43,11 @@
<a href="/videos"> <a href="/videos">
<div><img src="../img/play.svg">Записи</div> <div><img src="../img/play.svg">Записи</div>
</a> </a>
{{#if isAdmin}}
<a class="admin-panel" href="/admin">
<div><img src="../img/keyboard.svg">Админка</div>
</a>
{{/if}}
<a class="settings" href="/settings"> <a class="settings" href="/settings">
<div><img src="../img/gear.svg">Настройки</div> <div><img src="../img/gear.svg">Настройки</div>
</a> </a>

View File

@ -11,17 +11,17 @@
<header> <header>
<h1>Аргус</h1> <h1>Аргус</h1>
<h2><span>/</span> Название организации</h2> <h2><span>/</span> {{Organisation}}</h2>
</header> </header>
<section class="account-info"> <section class="account-info">
<div id="account-main"> <div id="account-main">
<img id="person" src="../img/person.svg"> <img id="person" src="../img/person.svg">
<span>Тестовое Имя</span> <span>{{User}}</span>
<img id="down" src="../img/down.svg"> <img id="down" src="../img/down.svg">
<img id="up" src="../img/up.svg"> <img id="up" src="../img/up.svg">
</div> </div>
<a href="/login"><div id="account-additional" class="additional">Выйти</div></a> <a href="/logout"><div id="account-additional" class="additional">Выйти</div></a>
</section> </section>
@ -43,6 +43,11 @@
<a href="/videos"> <a href="/videos">
<div><img src="../img/play.svg">Записи</div> <div><img src="../img/play.svg">Записи</div>
</a> </a>
{{#if isAdmin}}
<a class="admin-panel" href="/admin">
<div><img src="../img/keyboard.svg">Админка</div>
</a>
{{/if}}
<a class="settings" href="/settings"> <a class="settings" href="/settings">
<div><img src="../img/gear.svg">Настройки</div> <div><img src="../img/gear.svg">Настройки</div>
</a> </a>

View File

@ -23,7 +23,7 @@
<img id="down" src="../img/down.svg"> <img id="down" src="../img/down.svg">
<img id="up" src="../img/up.svg"> <img id="up" src="../img/up.svg">
</div> </div>
<a href="/login"><div id="account-additional" class="additional">Выйти</div></a> <a href="/logout"><div id="account-additional" class="additional">Выйти</div></a>
</section> </section>
@ -45,9 +45,11 @@
<a href="/videos"> <a href="/videos">
<div><img src="../img/play.svg">Записи</div> <div><img src="../img/play.svg">Записи</div>
</a> </a>
{{#if isAdmin}}
<a class="admin-panel" href="/admin"> <a class="admin-panel" href="/admin">
<div><img src="../img/keyboard.svg">Админка</div> <div><img src="../img/keyboard.svg">Админка</div>
</a> </a>
{{/if}}
<a class="settings" href="/settings"> <a class="settings" href="/settings">
<div><img src="../img/gear.svg">Настройки</div> <div><img src="../img/gear.svg">Настройки</div>
</a> </a>

View File

@ -25,7 +25,7 @@
<img id="down" src="../img/down.svg"> <img id="down" src="../img/down.svg">
<img id="up" src="../img/up.svg"> <img id="up" src="../img/up.svg">
</div> </div>
<a href="/login"><div id="account-additional" class="additional">Выйти</div></a> <a href="/logout"><div id="account-additional" class="additional">Выйти</div></a>
</section> </section>
@ -47,9 +47,11 @@
<a href="/videos"> <a href="/videos">
<div><img src="../img/play.svg">Записи</div> <div><img src="../img/play.svg">Записи</div>
</a> </a>
{{#if isAdmin}}
<a class="admin-panel" href="/admin"> <a class="admin-panel" href="/admin">
<div><img src="../img/keyboard.svg">Админка</div> <div><img src="../img/keyboard.svg">Админка</div>
</a> </a>
{{/if}}
<a class="settings" href="/settings"> <a class="settings" href="/settings">
<div><img src="../img/gear.svg">Настройки</div> <div><img src="../img/gear.svg">Настройки</div>
</a> </a>

View File

@ -1,32 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Авторизация</title>
<link rel="stylesheet" href="../styles/main.css" />
</head>
<body>
<section class="form right">
<form enctype="multipart/form-data" method="post" action="/postsignin">
<h1 style="margin-bottom: 40px;">Добро пожаловать в Аргус</h1>
<label for="login">Логин<span>*</span></label>
<input title="Введите логин" placeholder="Введите логин" name="login" type="text" required>
<label for="password">Пароль<span>*</span></label>
<input title="Введите пароль" placeholder="Введите пароль" name="password" type="password" required>
<button onclick="window.location.href='/'" type="button">Войти</button>
</form>
</section>
<video class="animation left" autoplay muted loop>
<source src="../img/traffic.mp4" type="video/mp4">
</video>
<span class="copyright left"><a href="https://dribbble.com/shots/15608015-Traffic">Видеоматериал создан Igor Kozak на Dribbble</a></span>
</body>
</html>

View File

@ -10,7 +10,7 @@
<body> <body>
<section class="form left"> <section class="form left">
<form enctype="multipart/form-data" method="post" action="/postsignin"> <form enctype="multipart/form-data" method="post" action="/setup" id="setupForm">
<h1>Добро пожаловать в Аргус</h1> <h1>Добро пожаловать в Аргус</h1>
<h2>Приступим к созданию организации</h2> <h2>Приступим к созданию организации</h2>
@ -26,7 +26,7 @@
<label for="repassword">Подтверждение<span>*</span></label> <label for="repassword">Подтверждение<span>*</span></label>
<input title="Повторите пароль" placeholder="Повторите пароль" name="repassword" type="password" required> <input title="Повторите пароль" placeholder="Повторите пароль" name="repassword" type="password" required>
<button onclick="window.location.href='/'" type="button">Установить</button> <button type="submit">Установить</button>
</form> </form>
</section> </section>
@ -34,7 +34,55 @@
<video class="animation right" autoplay muted loop> <video class="animation right" autoplay muted loop>
<source src="../img/traffic.mp4" type="video/mp4"> <source src="../img/traffic.mp4" type="video/mp4">
</video> </video>
<span class="copyright right"><a href="https://dribbble.com/shots/15608015-Traffic">Видеоматериал создан Igor Kozak на Dribbble</a></span> <span class="copyright right"><a href="https://dribbble.com/shots/15608015-Traffic">Видеоматериал создан Igor Kozak для 10Clouds</a></span>
<script>
document.addEventListener("DOMContentLoaded", function() {
const passwordInput = document.querySelector('input[name="password"]');
const repasswordInput = document.querySelector('input[name="repassword"]');
// Обработка отправки формы в формате JSON
const setupForm = document.getElementById('setupForm');
setupForm.addEventListener('submit', function(event) {
const password = passwordInput.value;
const repassword = repasswordInput.value;
if (password !== repassword) {
alert('Пароли не совпадают');
event.preventDefault();
return;
}
event.preventDefault();
const formData = new FormData(setupForm);
const jsonData = {};
formData.forEach((value, key) => {
jsonData[key] = value;
});
const xhr = new XMLHttpRequest();
xhr.open('POST', '/setup');
xhr.setRequestHeader('Content-Type', 'application/json;charset=UTF-8');
xhr.onload = function() {
if (xhr.status === 200) {
location.href = '/';
} else {
alert('Произошла ошибка при отправке данных');
window.location.reload();
}
};
xhr.onerror = function() {
// Ошибка сети
alert('Произошла ошибка сети');
};
xhr.send(JSON.stringify(jsonData));
});
});
</script>

View File

@ -21,7 +21,7 @@
<img id="down" src="../img/down.svg"> <img id="down" src="../img/down.svg">
<img id="up" src="../img/up.svg"> <img id="up" src="../img/up.svg">
</div> </div>
<a href="/login"><div id="account-additional" class="additional">Выйти</div></a> <a href="/logout"><div id="account-additional" class="additional">Выйти</div></a>
</section> </section>
@ -43,9 +43,11 @@
<a href="/videos"> <a href="/videos">
<div><img src="../img/play.svg">Записи</div> <div><img src="../img/play.svg">Записи</div>
</a> </a>
{{#if isAdmin}}
<a class="admin-panel" href="/admin"> <a class="admin-panel" href="/admin">
<div><img src="../img/keyboard.svg">Админка</div> <div><img src="../img/keyboard.svg">Админка</div>
</a> </a>
{{/if}}
<a class="settings" href="/settings"> <a class="settings" href="/settings">
<div><img src="../img/gear.svg">Настройки</div> <div><img src="../img/gear.svg">Настройки</div>
</a> </a>

View File

@ -23,7 +23,7 @@
<img id="down" src="../img/down.svg"> <img id="down" src="../img/down.svg">
<img id="up" src="../img/up.svg"> <img id="up" src="../img/up.svg">
</div> </div>
<a href="/login"><div id="account-additional" class="additional">Выйти</div></a> <a href="/logout"><div id="account-additional" class="additional">Выйти</div></a>
</section> </section>
@ -45,9 +45,11 @@
<a href="/videos"> <a href="/videos">
<div><img src="../img/play.svg">Записи</div> <div><img src="../img/play.svg">Записи</div>
</a> </a>
{{#if isAdmin}}
<a class="admin-panel" href="/admin"> <a class="admin-panel" href="/admin">
<div><img src="../img/keyboard.svg">Админка</div> <div><img src="../img/keyboard.svg">Админка</div>
</a> </a>
{{/if}}
<a class="settings" href="/settings"> <a class="settings" href="/settings">
<div><img src="../img/gear.svg">Настройки</div> <div><img src="../img/gear.svg">Настройки</div>
</a> </a>

View File

@ -11,17 +11,17 @@
<header> <header>
<h1>Аргус</h1> <h1>Аргус</h1>
<h2><span>/</span> Название организации</h2> <h2><span>/</span> {{Organisation}}</h2>
</header> </header>
<section class="account-info"> <section class="account-info">
<div id="account-main"> <div id="account-main">
<img id="person" src="../img/person.svg"> <img id="person" src="../img/person.svg">
<span>Тестовое Имя</span> <span>{{User}}</span>
<img id="down" src="../img/down.svg"> <img id="down" src="../img/down.svg">
<img id="up" src="../img/up.svg"> <img id="up" src="../img/up.svg">
</div> </div>
<a href="/login"><div id="account-additional" class="additional">Выйти</div></a> <a href="/logout"><div id="account-additional" class="additional">Выйти</div></a>
</section> </section>
@ -43,16 +43,18 @@
<a href="/videos"> <a href="/videos">
<div><img src="../img/play.svg">Записи</div> <div><img src="../img/play.svg">Записи</div>
</a> </a>
{{#if isAdmin}}
<a class="admin-panel" href="/admin"> <a class="admin-panel" href="/admin">
<div><img src="../img/keyboard.svg">Админка</div> <div><img src="../img/keyboard.svg">Админка</div>
</a> </a>
{{/if}}
<a class="settings" href="/settings"> <a class="settings" href="/settings">
<div class="selected"><img src="../img/gear.svg">Настройки</div> <div class="selected"><img src="../img/gear.svg">Настройки</div>
</a> </a>
</section> </section>
<section class="main"> <section class="main">
<!-- {{#if ifDBError}} {{#if ifDBError}}
<section class="dberror"> <section class="dberror">
<div class="erorr-container"> <div class="erorr-container">
<img src="../img/warning.svg"> <br> <img src="../img/warning.svg"> <br>
@ -61,7 +63,7 @@
<button type="button" onclick="location.reload();">Повторить попытку</button> <button type="button" onclick="location.reload();">Повторить попытку</button>
</div> </div>
</section> </section>
{{/if}} --> {{/if}}
<section style="display: none;" class="dberror" id="deleteConfirmation" > <section style="display: none;" class="dberror" id="deleteConfirmation" >
<div class="erorr-container"> <div class="erorr-container">
<div id="loader" class="loader"> <div id="loader" class="loader">

View File

@ -0,0 +1,72 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Авторизация</title>
<link rel="stylesheet" href="../styles/main.css" />
</head>
<body>
<section class="form right">
<form enctype="multipart/form-data" method="post" action="/login" id="loginForm">
<h1 style="margin-bottom: 40px;">Добро пожаловать в Аргус</h1>
<label for="login">Логин или Email<span>*</span></label>
<input placeholder="Введите логин или Email" name="email" type="text" required>
<label for="password">Пароль<span>*</span></label>
<input placeholder="Введите пароль" name="password" type="password" required>
<button type="submit">Войти</button>
</form>
</section>
<video class="animation left" autoplay muted loop>
<source src="../img/traffic.mp4" type="video/mp4">
</video>
<span class="copyright left"><a href="https://dribbble.com/shots/15608015-Traffic">Видеоматериал создан Igor Kozak для 10Clouds</a></span>
<script>
document.addEventListener("DOMContentLoaded", function() {
// Обработка отправки формы в формате JSON
const loginForm = document.getElementById('loginForm');
loginForm.addEventListener('submit', function(event) {
event.preventDefault();
const formData = new FormData(loginForm);
const jsonData = {};
formData.forEach((value, key) => {
jsonData[key] = value;
});
const xhr = new XMLHttpRequest();
xhr.open('POST', '/login');
xhr.setRequestHeader('Content-Type', 'application/json;charset=UTF-8');
xhr.onload = function() {
if (xhr.status === 200) {
location.href = '/';
} else if (xhr.status === 401) {
alert('Неверный логин или пароль');
} else {
alert('Произошла ошибка при отправке данных');
window.location.reload();
}
};
xhr.onerror = function() {
// Ошибка сети
alert('Произошла ошибка сети');
};
xhr.send(JSON.stringify(jsonData));
});
});
</script>
</body>
</html>

View File

@ -25,7 +25,7 @@
<img id="down" src="../img/down.svg"> <img id="down" src="../img/down.svg">
<img id="up" src="../img/up.svg"> <img id="up" src="../img/up.svg">
</div> </div>
<a href="/login"><div id="account-additional" class="additional">Выйти</div></a> <a href="/logout"><div id="account-additional" class="additional">Выйти</div></a>
</section> </section>
@ -47,9 +47,11 @@
<a href="/videos"> <a href="/videos">
<div class="selected"><img src="../img/play.svg">Записи</div> <div class="selected"><img src="../img/play.svg">Записи</div>
</a> </a>
{{#if isAdmin}}
<a class="admin-panel" href="/admin"> <a class="admin-panel" href="/admin">
<div><img src="../img/keyboard.svg">Админка</div> <div><img src="../img/keyboard.svg">Админка</div>
</a> </a>
{{/if}}
<a class="settings" href="/settings"> <a class="settings" href="/settings">
<div><img src="../img/gear.svg">Настройки</div> <div><img src="../img/gear.svg">Настройки</div>
</a> </a>

View File

@ -25,7 +25,7 @@
<img id="down" src="../img/down.svg"> <img id="down" src="../img/down.svg">
<img id="up" src="../img/up.svg"> <img id="up" src="../img/up.svg">
</div> </div>
<a href="/login"><div id="account-additional" class="additional">Выйти</div></a> <a href="/logout"><div id="account-additional" class="additional">Выйти</div></a>
</section> </section>
@ -47,9 +47,11 @@
<a href="/videos"> <a href="/videos">
<div class="selected"><img src="../img/play.svg">Записи</div> <div class="selected"><img src="../img/play.svg">Записи</div>
</a> </a>
{{#if isAdmin}}
<a class="admin-panel" href="/admin"> <a class="admin-panel" href="/admin">
<div><img src="../img/keyboard.svg">Админка</div> <div><img src="../img/keyboard.svg">Админка</div>
</a> </a>
{{/if}}
<a class="settings" href="/settings"> <a class="settings" href="/settings">
<div><img src="../img/gear.svg">Настройки</div> <div><img src="../img/gear.svg">Настройки</div>
</a> </a>