update Di 26. Mai 15:31:01 CEST 2020

This commit is contained in:
Robert Richter 2020-05-26 15:31:01 +02:00
parent a50a44b67a
commit 0a47010425
2 changed files with 161 additions and 159 deletions

View File

@ -1,111 +1,115 @@
module.exports = function (io, io_api, sql, app_cfg, waip) { module.exports = function (io, io_api, sql, app_cfg, waip) {
// Module laden // Module laden
const io_api = require('socket.io-client'); const io_api = require('socket.io-client');
// Endpoint-API // Socket.IO API
if (app_cfg.endpoint.enabled) {
const remote_api = io_api.connect(app_cfg.global.remoteapi, {
reconnect: true
});
} else {
const remote_api;
};
if (app_cfg.api.enabled) {
var nsp_api = io.of('/api');
// Module laden nsp_api.on('connection', function (socket) {
//client.js // 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');
// Add a connect listener // Neuen Einsatz speichern
remote_api.on('connect', function (remote_api) { socket.on('new_waip', function (data) {
console.log('Connected!'); sql.db_log('API', 'Neuer Einsatz von ' + remote_ip + ': ' + data);
}); waip.einsatz_speichern(data);
});
socket.on('connect_error', function (err) { socket.on('new_rmld', function (data) {
$('#waipModalTitle').html('FEHLER'); sql.db_save_rmld(data, function (result) {
$('#waipModalBody').html('Verbindung zum Server getrennt!'); if (result) {
$('#waipModal').modal('show'); waip.rmld_verteilen_by_uuid(data.waip_uuid, data.rmld_uuid);
}); sql.db_log('API', 'Rückmeldung von ' + remote_ip + ' gespeichert: ' + data);
} else {
remote_api.emit('CH01', 'me', 'test msg'); sql.db_log('API', 'Fehler beim speichern der Rückmeldung von ' + remote_ip + ': ' + data);
};
});
});
// Funktion um zu pruefen, ob Nachricht im JSON-Format ist // Disconnect
function isValidJSON(text) { socket.on('disconnect', function () {
try { sql.db_log('API', 'Schnittstelle von ' + remote_ip + ' (' + socket.id + ') geschlossen.');
JSON.parse(text); sql.db_client_delete(socket);
return true; });
} catch (error) {
return false;
}
};
//client.js
// Add a connect listener
remote_api.on('connect', function (remote_api) {
console.log('Connected!');
});
socket.on('connect_error', function (err) {
$('#waipModalTitle').html('FEHLER');
$('#waipModalBody').html('Verbindung zum Server getrennt!');
$('#waipModal').modal('show');
});
remote_api.emit('CH01', 'me', 'test msg');
return {
einsatz_speichern: einsatz_speichern,
waip_verteilen: waip_verteilen,
dbrd_verteilen: dbrd_verteilen,
rmld_verteilen_for_one_client: rmld_verteilen_for_one_client,
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); // Endpoint-API
}); if (app_cfg.endpoint.enabled) {
const remote_api = io_api.connect(app_cfg.global.remoteapi, {
reconnect: true
});
} else {
const remote_api;
};
// Module laden
//client.js
// Add a connect listener
remote_api.on('connect', function (remote_api) {
console.log('Connected!');
}); });
};
socket.on('connect_error', function (err) {
$('#waipModalTitle').html('FEHLER');
$('#waipModalBody').html('Verbindung zum Server getrennt!');
$('#waipModal').modal('show');
});
remote_api.emit('CH01', 'me', 'test msg');
// Funktion um zu pruefen, ob Nachricht im JSON-Format ist
function isValidJSON(text) {
try {
JSON.parse(text);
return true;
} catch (error) {
return false;
}
};
//client.js
// Add a connect listener
remote_api.on('connect', function (remote_api) {
console.log('Connected!');
});
socket.on('connect_error', function (err) {
$('#waipModalTitle').html('FEHLER');
$('#waipModalBody').html('Verbindung zum Server getrennt!');
$('#waipModal').modal('show');
});
remote_api.emit('CH01', 'me', 'test msg');
return {
einsatz_speichern: einsatz_speichern,
waip_verteilen: waip_verteilen,
dbrd_verteilen: dbrd_verteilen,
rmld_verteilen_for_one_client: rmld_verteilen_for_one_client,
rmld_verteilen_by_uuid: rmld_verteilen_by_uuid
};
}; };

View File

@ -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',
@ -65,9 +65,9 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
// Login-Formular verarbeiten // Login-Formular verarbeiten
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;
}; };
@ -77,16 +77,16 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
// Login mit IP verarbeiten // Login mit IP verarbeiten
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,31 +192,31 @@ 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;
delete einsatzdaten.strasse; delete einsatzdaten.strasse;
delete einsatzdaten.wgs84_x; delete einsatzdaten.wgs84_x;
delete einsatzdaten.wgs84_y; delete einsatzdaten.wgs84_y;
}; };
einsatzdaten.rmld_uuid = rmld_uuid; einsatzdaten.rmld_uuid = rmld_uuid;
res.render('rmld', { res.render('rmld', {
@ -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,31 +370,30 @@ 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',
user: req.user user: req.user
}); });
}); });
/* ######################## */ /* ######################## */
/* ##### Fehlerseiten ##### */ /* ##### Fehlerseiten ##### */
/* ######################## */ /* ######################## */
// 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', {
@ -404,4 +402,4 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
}); });
}); });
}; };