-
Notifications
You must be signed in to change notification settings - Fork 0
/
server.js
122 lines (104 loc) · 3.66 KB
/
server.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
const express = require('express');
const multer = require('multer');
const mongoose = require('mongoose');
const bodyParser = require('body-parser');
const session = require('express-session');
const bcrypt = require('bcryptjs');
const crypto = require('crypto');
const axios = require('axios');
const app = express();
app.use(bodyParser.json());
app.use(session({ secret: 'secret-key', resave: false, saveUninitialized: true }));
// Mongoose schema a model pro články a uživatele
const articleSchema = new mongoose.Schema({
title: String,
content: String,
image: String,
author: String,
date: { type: Date, default: Date.now }
});
const userSchema = new mongoose.Schema({
username: String,
password: String
});
const Article = mongoose.model('Article', articleSchema);
const User = mongoose.model('User', userSchema);
// Konfigurace Multer pro nahrávání obrázků
const storage = multer.diskStorage({
destination: function(req, file, cb) {
cb(null, 'uploads/');
},
filename: function(req, file, cb) {
cb(null, Date.now() + '-' + file.originalname);
}
});
const upload = multer({ storage: storage });
// Připojení k MongoDB
mongoose.connect('mongodb://localhost:27017/herni-zpravodaj', { useNewUrlParser: true, useUnifiedTopology: true });
// Discord webhook URL (zde vložte váš vlastní URL)
const discordWebhookUrl = 'YOUR_DISCORD_WEBHOOK_URL';
// Vytvoření základního uživatele ADMIN při prvním spuštění serveru
async function createAdminUser() {
const adminUser = await User.findOne({ username: 'ADMIN' });
if (!adminUser) {
const randomPassword = crypto.randomBytes(8).toString('hex');
const hashedPassword = await bcrypt.hash(randomPassword, 10);
const newUser = new User({
username: 'ADMIN',
password: hashedPassword
});
await newUser.save();
// Odeslání hesla na Discord webhook
await axios.post(discordWebhookUrl, {
content: `Admin account created.\nUsername: ADMIN\nPassword: ${randomPassword}`
});
} else {
console.log('Admin account already exists.');
}
}
createAdminUser();
// Registrace/Přihlášení
app.post('/login', async (req, res) => {
const { username, password } = req.body;
const user = await User.findOne({ username });
if (user && await bcrypt.compare(password, user.password)) {
req.session.user = username;
res.send('Přihlášení úspěšné');
} else {
res.status(401).send('Neplatné přihlašovací údaje');
}
});
app.post('/logout', (req, res) => {
req.session.destroy();
res.send('Odhlášení úspěšné');
});
// Vytvoření článku
app.post('/articles', upload.single('image'), (req, res) => {
if (!req.session.user) {
return res.status(401).send('Nepřihlášený uživatel');
}
const newArticle = new Article({
title: req.body.title,
content: req.body.content,
image: req.file.path,
author: req.session.user
});
newArticle.save((err) => {
if (err) {
return res.status(500).send('Chyba při ukládání článku');
}
res.send('Článek byl úspěšně publikován');
});
});
// Načítání článků
app.get('/articles', (req, res) => {
Article.find({}, (err, articles) => {
if (err) {
return res.status(500).send('Chyba při načítání článků');
}
res.json(articles);
});
});
app.listen(3000, () => {
console.log('Server běží na portu 3000');
});