update Di 26. Mai 15:31:01 CEST 2020
This commit is contained in:
parent
a50a44b67a
commit
0a47010425
@ -4,6 +4,45 @@ module.exports = function (io, io_api, sql, app_cfg, waip) {
|
|||||||
const io_api = require('socket.io-client');
|
const io_api = require('socket.io-client');
|
||||||
|
|
||||||
|
|
||||||
|
// 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;
|
||||||
|
//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
|
// Endpoint-API
|
||||||
if (app_cfg.endpoint.enabled) {
|
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, {
|
||||||
@ -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);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
};
|
};
|
||||||
@ -269,7 +269,6 @@ 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', {
|
||||||
@ -393,9 +392,8 @@ module.exports = function(app, sql, uuidv4, app_cfg, passport, auth, waip, udp)
|
|||||||
// 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