63 lines
3.1 KiB
JavaScript
Executable File
63 lines
3.1 KiB
JavaScript
Executable File
module.exports = function (io, sql, app_cfg, waip) {
|
|
|
|
// Module laden
|
|
//client.js
|
|
var io_api = require('socket.io-client');
|
|
var socket_api = io_api.connect(app_cfg.global.remoteapi, {
|
|
reconnect: true
|
|
});
|
|
|
|
// Add a connect listener
|
|
socket_api.on('connect', function (socket_api) {
|
|
console.log('Connected!');
|
|
});
|
|
socket_api.emit('CH01', 'me', 'test msg');
|
|
|
|
// Socket.IO Server
|
|
io.on('connection', function (socket) {
|
|
sql.db_log('WAIP', 'Wachalarm von ' + socket.request.connection.remoteAddress + ' (' + socket.id + ') geoeffnet');
|
|
//zuerst Server-Version senden, damit der Client diese prueft und die Seite ggf. neu lädt
|
|
io.sockets.to(socket.id).emit('io.version', app_cfg.global.app_id);
|
|
|
|
// Aufruf des Alarmmonitors einer bestimmten Wache verarbeiten
|
|
socket.on('wachen_id', function (wachen_id) {
|
|
sql.db_log('WAIP', 'Alarmmonitor Nr. ' + wachen_id + ' von ' + socket.request.connection.remoteAddress + ' (' + socket.id + ') aufgerufen');
|
|
// prüfen ob Wachenummer in der Datenbank hinterlegt ist
|
|
sql.db_wache_vorhanden(wachen_id, function (result) {
|
|
// wenn die Wachennummer vorhanden/plausibel dann weiter
|
|
if (result) {
|
|
// Socket-Room beitreiten
|
|
socket.join(wachen_id, function () {
|
|
// Socket-ID und Client-IP in der Datenbank speichern
|
|
sql.db_client_save(socket.id, socket.request.connection.remoteAddress, wachen_id);
|
|
// prüfen ob für diese Wache ein Einsatz vorhanden ist
|
|
sql.db_einsatz_vorhanden(wachen_id, socket.request.user.id, function (result_einsatz) {
|
|
if (result_einsatz) {
|
|
console.log(result_einsatz[0].waip_einsaetze_ID);
|
|
sql.db_log('WAIP', 'Einsatz ' + result_einsatz[0].waip_einsaetze_ID + ' fuer Wache ' + wachen_id + ' vorhanden');
|
|
//letzten Einsatz verteilen
|
|
waip.einsatz_verteilen(result_einsatz[0].waip_einsaetze_ID, socket.id, wachen_id);
|
|
sql.db_update_client_status(socket, result_einsatz[0].waip_einsaetze_ID);
|
|
//vorhanden Rückmeldungen verteilen
|
|
waip.rueckmeldung_verteilen_for_client(result_einsatz[0].waip_einsaetze_ID, socket.id, wachen_id);
|
|
} else {
|
|
sql.db_log('WAIP', 'Kein Einsatz fuer Wache ' + wachen_id + ' vorhanden, Standby');
|
|
//oder falls kein Einsatz vorhanden ist, dann
|
|
io.sockets.to(socket.id).emit('io.standby', null);
|
|
sql.db_update_client_status(socket, null);
|
|
};
|
|
});
|
|
});
|
|
} else {
|
|
sql.db_log('Fehler-WAIP', 'Fehler: Wachnnummer ' + wachen_id + 'nicht vorhanden');
|
|
io.sockets.to(socket.id).emit('io.error', 'Fehler: Wachnnummer \'' + wachen_id + '\' nicht vorhanden!');
|
|
};
|
|
});
|
|
});
|
|
// disconnect verarbeiten
|
|
socket.on('disconnect', function () {
|
|
sql.db_log('WAIP', 'Alarmmonitor von ' + socket.request.connection.remoteAddress + ' (' + socket.id + ') geschlossen');
|
|
sql.db_client_delete(socket.id);
|
|
});
|
|
});
|
|
}; |