update Di 26. Mai 16:01:01 CEST 2020
This commit is contained in:
parent
0a47010425
commit
85834350fb
@ -1,45 +1,44 @@
|
|||||||
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');
|
||||||
|
|
||||||
|
// Socket.IO API (anderer Server stellt Verbindung her und sendet Daten)
|
||||||
|
|
||||||
// Socket.IO API
|
if (app_cfg.api.enabled) {
|
||||||
|
// Namespace API
|
||||||
|
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;
|
||||||
|
|
||||||
if (app_cfg.api.enabled) {
|
//TODO pruefen ob Verbindung mit passendem Geheimnis und aus IP-Bereich
|
||||||
var nsp_api = io.of('/api');
|
|
||||||
|
|
||||||
nsp_api.on('connection', function (socket) {
|
// in Liste der Clients mit aufnehmen
|
||||||
// versuche Remote-IP zu ermitteln
|
sql.db_update_client_status(socket, 'api');
|
||||||
var remote_ip = socket.handshake.headers["x-real-ip"] || socket.handshake.headers['x-forwarded-for'] || socket.request.connection.remoteAddress;
|
// Neuen Einsatz speichern
|
||||||
//TODO pruefen ob Verbindung mit passendem Geheimnis und aus IP-Bereich
|
socket.on('new_waip', function (data) {
|
||||||
//secret: 'asdfwert1234567890#',
|
waip.einsatz_speichern(data);
|
||||||
//access_list: ['192.168.2.20', '192.168.2.30']
|
sql.db_log('API', 'Neuer Einsatz von ' + remote_ip + ': ' + data);
|
||||||
|
});
|
||||||
// in Liste der Clients mit aufnehmen
|
// neue externe Rueckmeldung speichern
|
||||||
sql.db_update_client_status(socket, 'api');
|
socket.on('new_rmld', function (data) {
|
||||||
// Neuen Einsatz speichern
|
sql.db_save_rmld(data, function (result) {
|
||||||
socket.on('new_waip', function (data) {
|
if (result) {
|
||||||
sql.db_log('API', 'Neuer Einsatz von ' + remote_ip + ': ' + data);
|
waip.rmld_verteilen_by_uuid(data.waip_uuid, data.rmld_uuid);
|
||||||
waip.einsatz_speichern(data);
|
sql.db_log('API', 'Rückmeldung von ' + remote_ip + ' gespeichert: ' + data);
|
||||||
});
|
} else {
|
||||||
socket.on('new_rmld', function (data) {
|
sql.db_log('API', 'Fehler beim speichern der Rückmeldung von ' + remote_ip + ': ' + 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);
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
};
|
});
|
||||||
|
// Disconnect
|
||||||
|
socket.on('disconnect', function () {
|
||||||
|
sql.db_log('API', 'Schnittstelle von ' + remote_ip + ' (' + socket.id + ') geschlossen.');
|
||||||
|
sql.db_client_delete(socket);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user