update Di 26. Mai 15:31:01 CEST 2020
This commit is contained in:
parent
a50a44b67a
commit
0a47010425
@ -4,8 +4,47 @@ module.exports = function (io, io_api, sql, app_cfg, waip) {
|
|||||||
const io_api = require('socket.io-client');
|
const io_api = require('socket.io-client');
|
||||||
|
|
||||||
|
|
||||||
// Endpoint-API
|
// Socket.IO API
|
||||||
if (app_cfg.endpoint.enabled) {
|
|
||||||
|
if (app_cfg.api.enabled) {
|
||||||
|
var nsp_api = io.of('/api');
|
||||||
|
|
||||||
|
nsp_api.on('connection', function (socket) {
|
||||||
|
// versuche Remote-IP zu ermitteln
|
||||||
|
var remote_ip = socket.handshake.headers["x-real-ip"] || socket.handshake.headers['x-forwarded-for'] || socket.request.connection.remoteAddress;
|
||||||
|
//TODO pruefen ob Verbindung mit passendem Geheimnis und aus IP-Bereich
|
||||||
|
//secret: 'asdfwert1234567890#',
|
||||||
|
//access_list: ['192.168.2.20', '192.168.2.30']
|
||||||
|
|
||||||
|
// in Liste der Clients mit aufnehmen
|
||||||
|
sql.db_update_client_status(socket, 'api');
|
||||||
|
// Neuen Einsatz speichern
|
||||||
|
socket.on('new_waip', function (data) {
|
||||||
|
sql.db_log('API', 'Neuer Einsatz von ' + remote_ip + ': ' + data);
|
||||||
|
waip.einsatz_speichern(data);
|
||||||
|
});
|
||||||
|
socket.on('new_rmld', function (data) {
|
||||||
|
sql.db_save_rmld(data, function (result) {
|
||||||
|
if (result) {
|
||||||
|
waip.rmld_verteilen_by_uuid(data.waip_uuid, data.rmld_uuid);
|
||||||
|
sql.db_log('API', 'Rückmeldung von ' + remote_ip + ' gespeichert: ' + data);
|
||||||
|
} else {
|
||||||
|
sql.db_log('API', 'Fehler beim speichern der Rückmeldung von ' + remote_ip + ': ' + data);
|
||||||
|
};
|
||||||
|
});
|
||||||
|
});
|
||||||
|
// Disconnect
|
||||||
|
socket.on('disconnect', function () {
|
||||||
|
sql.db_log('API', 'Schnittstelle von ' + remote_ip + ' (' + socket.id + ') geschlossen.');
|
||||||
|
sql.db_client_delete(socket);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// Endpoint-API
|
||||||
|
if (app_cfg.endpoint.enabled) {
|
||||||
const remote_api = io_api.connect(app_cfg.global.remoteapi, {
|
const remote_api = io_api.connect(app_cfg.global.remoteapi, {
|
||||||
reconnect: true
|
reconnect: true
|
||||||
});
|
});
|
||||||
@ -70,42 +109,7 @@ if (app_cfg.endpoint.enabled) {
|
|||||||
rmld_verteilen_by_uuid: rmld_verteilen_by_uuid
|
rmld_verteilen_by_uuid: rmld_verteilen_by_uuid
|
||||||
};
|
};
|
||||||
|
|
||||||
// Socket.IO API
|
|
||||||
|
|
||||||
if (app_cfg.api.enabled) {
|
|
||||||
var nsp_api = io.of('/api');
|
|
||||||
|
|
||||||
nsp_api.on('connection', function (socket) {
|
|
||||||
// versuche Remote-IP zu ermitteln
|
|
||||||
var remote_ip = socket.handshake.headers["x-real-ip"] || socket.handshake.headers['x-forwarded-for'] || socket.request.connection.remoteAddress;
|
|
||||||
//FIXME pruefen ob Verbindung mit passendem Secret und aus IP-Bereich
|
|
||||||
//secret: 'asdfwert1234567890#',
|
|
||||||
//access_list: ['192.168.2.20', '192.168.2.30']
|
|
||||||
|
|
||||||
// in Liste der Clients mit aufnehmen
|
|
||||||
sql.db_update_client_status(socket, 'api');
|
|
||||||
// Neuen Einsatz speichern
|
|
||||||
socket.on('new_waip', function (data) {
|
|
||||||
sql.db_log('API', 'Neuer Einsatz von ' + remote_ip + ': ' + data);
|
|
||||||
waip.einsatz_speichern(data);
|
|
||||||
});
|
|
||||||
socket.on('new_rmld', function (data) {
|
|
||||||
sql.db_save_rmld(data, function (result) {
|
|
||||||
if (result) {
|
|
||||||
waip.rmld_verteilen_by_uuid(data.waip_uuid, data.rmld_uuid);
|
|
||||||
sql.db_log('API', 'Rückmeldung von ' + remote_ip + ' gespeichert: ' + data);
|
|
||||||
} else {
|
|
||||||
sql.db_log('API', 'Fehler beim speichern der Rückmeldung von ' + remote_ip + ': ' + data);
|
|
||||||
};
|
|
||||||
});
|
|
||||||
});
|
|
||||||
// Disconnect
|
|
||||||
socket.on('disconnect', function () {
|
|
||||||
sql.db_log('API', 'Schnittstelle von ' + remote_ip + ' (' + socket.id + ') geschlossen.');
|
|
||||||
sql.db_client_delete(socket);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
};
|
};
|
||||||
@ -1,11 +1,11 @@
|
|||||||
module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp) {
|
module.exports = function (app, sql, uuidv4, app_cfg, passport, auth, waip, udp) {
|
||||||
|
|
||||||
/* ########################### */
|
/* ########################### */
|
||||||
/* ##### Statische Seiten #### */
|
/* ##### Statische Seiten #### */
|
||||||
/* ########################### */
|
/* ########################### */
|
||||||
|
|
||||||
// Startseite
|
// Startseite
|
||||||
app.get('/', function(req, res) {
|
app.get('/', function (req, res) {
|
||||||
res.render('home', {
|
res.render('home', {
|
||||||
public: app_cfg.public,
|
public: app_cfg.public,
|
||||||
title: 'Startseite',
|
title: 'Startseite',
|
||||||
@ -14,7 +14,7 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Ueber die Anwendung
|
// Ueber die Anwendung
|
||||||
app.get('/about', function(req, res) {
|
app.get('/about', function (req, res) {
|
||||||
res.render('about', {
|
res.render('about', {
|
||||||
public: app_cfg.public,
|
public: app_cfg.public,
|
||||||
title: 'Über',
|
title: 'Über',
|
||||||
@ -23,7 +23,7 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Impressum
|
// Impressum
|
||||||
app.get('/impressum', function(req, res) {
|
app.get('/impressum', function (req, res) {
|
||||||
if (app_cfg.public.ext_imprint) {
|
if (app_cfg.public.ext_imprint) {
|
||||||
res.redirect(app_cfg.public.url_imprint);
|
res.redirect(app_cfg.public.url_imprint);
|
||||||
} else {
|
} else {
|
||||||
@ -36,7 +36,7 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Datenschutzerklaerung
|
// Datenschutzerklaerung
|
||||||
app.get('/datenschutz', function(req, res) {
|
app.get('/datenschutz', function (req, res) {
|
||||||
if (app_cfg.public.ext_privacy) {
|
if (app_cfg.public.ext_privacy) {
|
||||||
res.redirect(app_cfg.public.url_privacy);
|
res.redirect(app_cfg.public.url_privacy);
|
||||||
} else {
|
} else {
|
||||||
@ -53,7 +53,7 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
/* ##################### */
|
/* ##################### */
|
||||||
|
|
||||||
// Loginseite
|
// Loginseite
|
||||||
app.get('/login', function(req, res) {
|
app.get('/login', function (req, res) {
|
||||||
res.render('login', {
|
res.render('login', {
|
||||||
public: app_cfg.public,
|
public: app_cfg.public,
|
||||||
title: 'Login',
|
title: 'Login',
|
||||||
@ -66,8 +66,8 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
app.post('/login', passport.authenticate('local', {
|
app.post('/login', passport.authenticate('local', {
|
||||||
failureRedirect: '/login',
|
failureRedirect: '/login',
|
||||||
failureFlash: 'Login fehlgeschlagen! Bitte prüfen Sie Benutzername und Passwort.'
|
failureFlash: 'Login fehlgeschlagen! Bitte prüfen Sie Benutzername und Passwort.'
|
||||||
}), function(req, res) {
|
}), function (req, res) {
|
||||||
if(req.body.rememberme){
|
if (req.body.rememberme) {
|
||||||
// der Benutzer muss sich fuer 5 Jahre nicht anmelden
|
// der Benutzer muss sich fuer 5 Jahre nicht anmelden
|
||||||
req.session.cookie.maxAge = 5 * 365 * 24 * 60 * 60 * 1000;
|
req.session.cookie.maxAge = 5 * 365 * 24 * 60 * 60 * 1000;
|
||||||
};
|
};
|
||||||
@ -78,15 +78,15 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
app.post('/login_ip', passport.authenticate('ip', {
|
app.post('/login_ip', passport.authenticate('ip', {
|
||||||
failureRedirect: '/login',
|
failureRedirect: '/login',
|
||||||
failureFlash: 'Login mittels IP-Adresse fehlgeschlagen!'
|
failureFlash: 'Login mittels IP-Adresse fehlgeschlagen!'
|
||||||
}), function(req, res) {
|
}), function (req, res) {
|
||||||
// der Benutzer muss sich fuer 5 Jahre nicht anmelden
|
// der Benutzer muss sich fuer 5 Jahre nicht anmelden
|
||||||
req.session.cookie.maxAge = 5 * 365 * 24 * 60 * 60 * 1000;
|
req.session.cookie.maxAge = 5 * 365 * 24 * 60 * 60 * 1000;
|
||||||
res.redirect('/');
|
res.redirect('/');
|
||||||
});
|
});
|
||||||
|
|
||||||
// Logout verarbeiten
|
// Logout verarbeiten
|
||||||
app.post('/logout', function(req, res) {
|
app.post('/logout', function (req, res) {
|
||||||
req.session.destroy(function(err) {
|
req.session.destroy(function (err) {
|
||||||
res.redirect('/');
|
res.redirect('/');
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
@ -96,8 +96,8 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
/* ######################### */
|
/* ######################### */
|
||||||
|
|
||||||
// Einstellungen anzeigen
|
// Einstellungen anzeigen
|
||||||
app.get('/config', auth.ensureAuthenticated, function(req, res) {
|
app.get('/config', auth.ensureAuthenticated, function (req, res) {
|
||||||
sql.db_get_userconfig(req.user.id, function(data) {
|
sql.db_get_userconfig(req.user.id, function (data) {
|
||||||
res.render('user/user_config', {
|
res.render('user/user_config', {
|
||||||
public: app_cfg.public,
|
public: app_cfg.public,
|
||||||
title: 'Einstellungen',
|
title: 'Einstellungen',
|
||||||
@ -108,8 +108,8 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Einstellungen speichern
|
// Einstellungen speichern
|
||||||
app.post('/config', auth.ensureAuthenticated, function(req, res) {
|
app.post('/config', auth.ensureAuthenticated, function (req, res) {
|
||||||
sql.db_set_userconfig(req.user.id, req.body.set_reset_counter, function(data) {
|
sql.db_set_userconfig(req.user.id, req.body.set_reset_counter, function (data) {
|
||||||
res.redirect('/config');
|
res.redirect('/config');
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@ -119,8 +119,8 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
/* ##################### */
|
/* ##################### */
|
||||||
|
|
||||||
// /waip nach /waip/0 umleiten
|
// /waip nach /waip/0 umleiten
|
||||||
app.get('/waip', function(req, res) {
|
app.get('/waip', function (req, res) {
|
||||||
sql.db_get_alle_wachen(function(data) {
|
sql.db_get_alle_wachen(function (data) {
|
||||||
res.render('overviews/overview_waip', {
|
res.render('overviews/overview_waip', {
|
||||||
public: app_cfg.public,
|
public: app_cfg.public,
|
||||||
title: 'Alarmmonitor',
|
title: 'Alarmmonitor',
|
||||||
@ -131,9 +131,9 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Alarmmonitor aufloesen /waip/<wachennummer>
|
// Alarmmonitor aufloesen /waip/<wachennummer>
|
||||||
app.get('/waip/:wachen_id', function(req, res, next) {
|
app.get('/waip/:wachen_id', function (req, res, next) {
|
||||||
var parmeter_id = req.params.wachen_id;
|
var parmeter_id = req.params.wachen_id;
|
||||||
sql.db_wache_vorhanden(parmeter_id, function(wache) {
|
sql.db_wache_vorhanden(parmeter_id, function (wache) {
|
||||||
if (wache) {
|
if (wache) {
|
||||||
res.render('waip', {
|
res.render('waip', {
|
||||||
public: app_cfg.public,
|
public: app_cfg.public,
|
||||||
@ -156,8 +156,8 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
/* ######################## */
|
/* ######################## */
|
||||||
|
|
||||||
// Dasboard-Uebersicht
|
// Dasboard-Uebersicht
|
||||||
app.get('/dbrd', function(req, res) {
|
app.get('/dbrd', function (req, res) {
|
||||||
sql.db_get_active_waips(function(data) {
|
sql.db_get_active_waips(function (data) {
|
||||||
res.render('overviews/overview_dbrd', {
|
res.render('overviews/overview_dbrd', {
|
||||||
public: app_cfg.public,
|
public: app_cfg.public,
|
||||||
title: 'Dashboard',
|
title: 'Dashboard',
|
||||||
@ -168,9 +168,9 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Dasboard fuer einen Einsatz
|
// Dasboard fuer einen Einsatz
|
||||||
app.get('/dbrd/:dbrd_uuid', function(req, res, next) {
|
app.get('/dbrd/:dbrd_uuid', function (req, res, next) {
|
||||||
var dbrd_uuid = req.params.dbrd_uuid;
|
var dbrd_uuid = req.params.dbrd_uuid;
|
||||||
sql.db_einsatz_uuid_vorhanden(dbrd_uuid, function(wache) {
|
sql.db_einsatz_uuid_vorhanden(dbrd_uuid, function (wache) {
|
||||||
if (wache) {
|
if (wache) {
|
||||||
res.render('dbrd', {
|
res.render('dbrd', {
|
||||||
public: app_cfg.public,
|
public: app_cfg.public,
|
||||||
@ -192,25 +192,25 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
/* ######################## */
|
/* ######################## */
|
||||||
|
|
||||||
// Rueckmeldungs-Aufruf ohne waip_uuid eblehnen
|
// Rueckmeldungs-Aufruf ohne waip_uuid eblehnen
|
||||||
app.get('/rmld', function(req, res, next) {
|
app.get('/rmld', function (req, res, next) {
|
||||||
var err = new Error('Rückmeldungen sind nur mit gültiger Einsatz-ID erlaubt!');
|
var err = new Error('Rückmeldungen sind nur mit gültiger Einsatz-ID erlaubt!');
|
||||||
err.status = 404;
|
err.status = 404;
|
||||||
next(err);
|
next(err);
|
||||||
});
|
});
|
||||||
|
|
||||||
// Rueckmeldungs-Aufruf mit waip_uuid aber ohne rmld_uuid an zufällige rmld_uuid weiterleiten
|
// Rueckmeldungs-Aufruf mit waip_uuid aber ohne rmld_uuid an zufällige rmld_uuid weiterleiten
|
||||||
app.get('/rmld/:waip_uuid', function(req, res, next) {
|
app.get('/rmld/:waip_uuid', function (req, res, next) {
|
||||||
res.redirect('/rmld/' + req.params.waip_uuid + '/' + uuidv4());
|
res.redirect('/rmld/' + req.params.waip_uuid + '/' + uuidv4());
|
||||||
});
|
});
|
||||||
|
|
||||||
// Rueckmeldung anzeigen /rueckmeldung/waip_uuid/rmld_uuid
|
// Rueckmeldung anzeigen /rueckmeldung/waip_uuid/rmld_uuid
|
||||||
app.get('/rmld/:waip_uuid/:rmld_uuid', function(req, res, next) {
|
app.get('/rmld/:waip_uuid/:rmld_uuid', function (req, res, next) {
|
||||||
|
|
||||||
var waip_uuid = req.params.waip_uuid;
|
var waip_uuid = req.params.waip_uuid;
|
||||||
var rmld_uuid = req.params.rmld_uuid;
|
var rmld_uuid = req.params.rmld_uuid;
|
||||||
sql.db_get_einsatzdaten_by_uuid(waip_uuid, function(einsatzdaten) {
|
sql.db_get_einsatzdaten_by_uuid(waip_uuid, function (einsatzdaten) {
|
||||||
if (einsatzdaten) {
|
if (einsatzdaten) {
|
||||||
sql.db_check_permission(req.user, einsatzdaten.id, function(valid) {
|
sql.db_check_permission(req.user, einsatzdaten.id, function (valid) {
|
||||||
if (!valid) {
|
if (!valid) {
|
||||||
delete einsatzdaten.objekt;
|
delete einsatzdaten.objekt;
|
||||||
delete einsatzdaten.besonderheiten;
|
delete einsatzdaten.besonderheiten;
|
||||||
@ -237,17 +237,17 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Rueckmeldung entgegennehmen
|
// Rueckmeldung entgegennehmen
|
||||||
app.post('/rmld/:waip_uuid/:rmld_uuid', function(req, res) {
|
app.post('/rmld/:waip_uuid/:rmld_uuid', function (req, res) {
|
||||||
var waip_uuid = req.body.waip_uuid;
|
var waip_uuid = req.body.waip_uuid;
|
||||||
var rmld_uuid = req.body.rmld_uuid;
|
var rmld_uuid = req.body.rmld_uuid;
|
||||||
sql.db_save_rmld(req.body, function(result){
|
sql.db_save_rmld(req.body, function (result) {
|
||||||
if (result) {
|
if (result) {
|
||||||
req.flash('successMessage', 'Rückmeldung erfolgreich gesendet, auf zum Einsatz!');
|
req.flash('successMessage', 'Rückmeldung erfolgreich gesendet, auf zum Einsatz!');
|
||||||
res.redirect('/rmld/' + waip_uuid + '/' + rmld_uuid );
|
res.redirect('/rmld/' + waip_uuid + '/' + rmld_uuid);
|
||||||
waip.rmld_verteilen_by_uuid(waip_uuid, rmld_uuid);
|
waip.rmld_verteilen_by_uuid(waip_uuid, rmld_uuid);
|
||||||
} else {
|
} else {
|
||||||
req.flash('errorMessage', 'Fehler beim Senden der Rückmeldung!');
|
req.flash('errorMessage', 'Fehler beim Senden der Rückmeldung!');
|
||||||
res.redirect('/rmld/' + waip_uuid + '/' + rmld_uuid );
|
res.redirect('/rmld/' + waip_uuid + '/' + rmld_uuid);
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@ -257,8 +257,8 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
/* ########################## */
|
/* ########################## */
|
||||||
|
|
||||||
// verbundene Clients anzeigen
|
// verbundene Clients anzeigen
|
||||||
app.get('/adm_show_clients', auth.ensureAdmin, function(req, res) {
|
app.get('/adm_show_clients', auth.ensureAdmin, function (req, res) {
|
||||||
sql.db_get_active_clients(function(data) {
|
sql.db_get_active_clients(function (data) {
|
||||||
res.render('admin/adm_show_clients', {
|
res.render('admin/adm_show_clients', {
|
||||||
public: app_cfg.public,
|
public: app_cfg.public,
|
||||||
title: 'Verbundene PCs/Benutzer',
|
title: 'Verbundene PCs/Benutzer',
|
||||||
@ -269,9 +269,8 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
});
|
});
|
||||||
|
|
||||||
// laufende Einsaetze anzeigen
|
// laufende Einsaetze anzeigen
|
||||||
// TODO: eventuell unter Dashboard oder Startseite anzeigen
|
app.get('/adm_show_missions', auth.ensureAdmin, function (req, res) {
|
||||||
app.get('/adm_show_missions', auth.ensureAdmin, function(req, res) {
|
sql.db_get_active_waips(function (data) {
|
||||||
sql.db_get_active_waips(function(data) {
|
|
||||||
res.render('admin/adm_show_missions', {
|
res.render('admin/adm_show_missions', {
|
||||||
public: app_cfg.public,
|
public: app_cfg.public,
|
||||||
title: 'Akutelle Einsätze',
|
title: 'Akutelle Einsätze',
|
||||||
@ -282,8 +281,8 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Logdatei
|
// Logdatei
|
||||||
app.get('/adm_show_log', auth.ensureAdmin, function(req, res) {
|
app.get('/adm_show_log', auth.ensureAdmin, function (req, res) {
|
||||||
sql.db_get_log(function(data) {
|
sql.db_get_log(function (data) {
|
||||||
res.render('admin/adm_show_log', {
|
res.render('admin/adm_show_log', {
|
||||||
public: app_cfg.public,
|
public: app_cfg.public,
|
||||||
title: 'Log-Datei',
|
title: 'Log-Datei',
|
||||||
@ -294,7 +293,7 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
});
|
});
|
||||||
|
|
||||||
// direkten Alarm ausloesen
|
// direkten Alarm ausloesen
|
||||||
app.get('/adm_run_alert', auth.ensureAdmin, function(req, res) {
|
app.get('/adm_run_alert', auth.ensureAdmin, function (req, res) {
|
||||||
res.render('admin/adm_run_alert', {
|
res.render('admin/adm_run_alert', {
|
||||||
public: app_cfg.public,
|
public: app_cfg.public,
|
||||||
title: 'Test-Alarm',
|
title: 'Test-Alarm',
|
||||||
@ -302,14 +301,14 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
app.post('/adm_run_alert', auth.ensureAdmin, function(req, res) {
|
app.post('/adm_run_alert', auth.ensureAdmin, function (req, res) {
|
||||||
udp.send_message(req.body.test_alert);
|
udp.send_message(req.body.test_alert);
|
||||||
res.redirect('/adm_run_alert');
|
res.redirect('/adm_run_alert');
|
||||||
});
|
});
|
||||||
|
|
||||||
// Benutzer editieren
|
// Benutzer editieren
|
||||||
app.get('/adm_edit_users', auth.ensureAdmin, function(req, res) {
|
app.get('/adm_edit_users', auth.ensureAdmin, function (req, res) {
|
||||||
sql.db_get_users(function(data) {
|
sql.db_get_users(function (data) {
|
||||||
res.render('admin/adm_edit_users', {
|
res.render('admin/adm_edit_users', {
|
||||||
public: app_cfg.public,
|
public: app_cfg.public,
|
||||||
title: 'Benutzer und Rechte verwalten',
|
title: 'Benutzer und Rechte verwalten',
|
||||||
@ -321,7 +320,7 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
app.post('/adm_edit_users', auth.ensureAdmin, function(req, res) {
|
app.post('/adm_edit_users', auth.ensureAdmin, function (req, res) {
|
||||||
if (req.user && req.user.permissions == "admin") {
|
if (req.user && req.user.permissions == "admin") {
|
||||||
switch (req.body["modal_method"]) {
|
switch (req.body["modal_method"]) {
|
||||||
case "DELETE":
|
case "DELETE":
|
||||||
@ -344,7 +343,7 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
/* ###################### */
|
/* ###################### */
|
||||||
|
|
||||||
// Wachalarm-Uhr testen
|
// Wachalarm-Uhr testen
|
||||||
app.get('/test_clock', function(req, res) {
|
app.get('/test_clock', function (req, res) {
|
||||||
res.render('tests/test_clock', {
|
res.render('tests/test_clock', {
|
||||||
public: app_cfg.public,
|
public: app_cfg.public,
|
||||||
title: 'Test Uhr',
|
title: 'Test Uhr',
|
||||||
@ -353,7 +352,7 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Alarmmonitor testen
|
// Alarmmonitor testen
|
||||||
app.get('/test_wachalarm', function(req, res) {
|
app.get('/test_wachalarm', function (req, res) {
|
||||||
res.render('tests/test_wachalarm', {
|
res.render('tests/test_wachalarm', {
|
||||||
public: app_cfg.public,
|
public: app_cfg.public,
|
||||||
title: 'Test Wachalarm',
|
title: 'Test Wachalarm',
|
||||||
@ -362,7 +361,7 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Rueckmeldung testen
|
// Rueckmeldung testen
|
||||||
app.get('/test_rueckmeldung', function(req, res) {
|
app.get('/test_rueckmeldung', function (req, res) {
|
||||||
res.render('tests/test_rueckmeldung', {
|
res.render('tests/test_rueckmeldung', {
|
||||||
public: app_cfg.public,
|
public: app_cfg.public,
|
||||||
title: 'Test Einsatz-Rückmeldung',
|
title: 'Test Einsatz-Rückmeldung',
|
||||||
@ -371,7 +370,7 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Dashboard testen
|
// Dashboard testen
|
||||||
app.get('/test_dashboard', function(req, res) {
|
app.get('/test_dashboard', function (req, res) {
|
||||||
res.render('tests/test_dashboard', {
|
res.render('tests/test_dashboard', {
|
||||||
public: app_cfg.public,
|
public: app_cfg.public,
|
||||||
title: 'Test Dashboard',
|
title: 'Test Dashboard',
|
||||||
@ -384,18 +383,17 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
/* ######################## */
|
/* ######################## */
|
||||||
|
|
||||||
// 404 abfangen und an error handler weiterleiten
|
// 404 abfangen und an error handler weiterleiten
|
||||||
app.use(function(req, res, next) {
|
app.use(function (req, res, next) {
|
||||||
var err = new Error('Seite nicht gefunden!');
|
var err = new Error('Seite nicht gefunden!');
|
||||||
err.status = 404;
|
err.status = 404;
|
||||||
next(err);
|
next(err);
|
||||||
});
|
});
|
||||||
|
|
||||||
// error handler
|
// error handler
|
||||||
app.use(function(err, req, res, next) {
|
app.use(function (err, req, res, next) {
|
||||||
// set locals, only providing error in development
|
// set locals, only providing error in development
|
||||||
// TODO: Development Modus abfangen
|
|
||||||
res.locals.message = err.message;
|
res.locals.message = err.message;
|
||||||
res.locals.error = req.app.get('env') === 'development' ? err : {};
|
res.locals.error = app_cfg.global.development ? err : {};
|
||||||
// render the error page
|
// render the error page
|
||||||
res.status(err.status || 500);
|
res.status(err.status || 500);
|
||||||
res.render('error', {
|
res.render('error', {
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user