public void cliente_servicio() { try { sincronico = true; AlarmasObj mensajeEnvioRecep = new AlarmasObj(); this.comadoToATM.setPonerEnServicio(); string datoEnvio = this.comadoToATM.getTramaComandoTerminal(); string datoRespuesta = ""; datoIn("CONEXION NUEVA TERMINAL :" + terminal.codigo); enviarDato = true; while (sincronico) { if (enviarDato) { clienteConectado = true; datoEnvio = comadoToATM.getTramaComandoTerminal(); envio_string(datoEnvio); mensajeEnvioRecep = parseoAlrma.parseaTramaIngreso(datoEnvio.Substring(2, datoEnvio.Length - 2)); mensajeEnvioRecep.envio_recepcion = 0;//cero envio, uno recibo terminalArchivo.escritura_archivo_string(">>>[" + datoEnvio.Length + "] : " + datoEnvio); enviarDato = false; datoIn("[" + terminal.codigo + "]:" + datoEnvio.Substring(2, datoEnvio.Length - 2)); conBdd.insertar_alarmas(mensajeEnvioRecep); datoEnvio = ""; } datoRespuesta = recepcion_de_datos(); if (!string.IsNullOrEmpty(datoRespuesta) && datoRespuesta.Length > 2) { terminalArchivo.escritura_archivo_string("<<<[" + datoRespuesta.Length + "] : " + datoRespuesta); datoResp("[" + terminal.codigo + "]:" + datoRespuesta.Substring(2, datoRespuesta.Length - 2)); mensajeEnvioRecep = parseoAlrma.parseaTramaIngreso(datoRespuesta.Substring(2, datoRespuesta.Length - 2)); mensajeEnvioRecep.envio_recepcion = 1; //cero envio, uno recibo /*Si al momento de inserta devuelve 1 se procede con el envio de la notificacion a los usuarios*/ string [] resultado = conBdd.insertar_alarmas(mensajeEnvioRecep); string enviarStr = resultado[1]; string id_suceso = resultado[0]; int enviar = int.Parse(enviarStr); if (mensajeEnvioRecep.descriptor != null) { if (mensajeEnvioRecep.descriptor.Equals("F")) { if (mensajeEnvioRecep.id_tipo_dispositivo.Equals("1")) { List <MonitoreoDispositivos> mts = parseoAlrma.parseaTramaAlarmaDispositivo(mensajeEnvioRecep); foreach (MonitoreoDispositivos tmp in mts) { conBdd.insertar_actualizar_monitoreo_dispositivos(tmp); } } } } else if (mensajeEnvioRecep.id_tipo_dispositivo != null) { if (mensajeEnvioRecep.id_tipo_dispositivo.Equals("P")) { /*con estado 2 indica si entro o no a modo supervisor*/ if (mensajeEnvioRecep.estado_dispositivo.Equals("2")) { terminal.modoSupervisor = mensajeEnvioRecep.error_severidad == "1"; conBdd.actualizar_terminal(terminal); } } } if (enviar == 1) { mensajeEnvioRecep.id_alarma = int.Parse(id_suceso); if (mensajeEnvioRecep.error_severidad == null) { mensajeEnvioRecep.error_severidad = "99"; } DetalleDescripcionObj detalleDes = conBdd.obtener_detalle_por_alarma_terminal(mensajeEnvioRecep); //string mensaje = conBdd.obtener_descripcion_error(int.Parse(mensajeEnvioRecep.error_severidad), mensajeEnvioRecep.id_tipo_dispositivo); detalleDes = parseoAlrma.procesamientoDescripcion(detalleDes); string mensaje = detalleDes.detalle_descripcion; if (string.IsNullOrEmpty(mensaje)) { mensaje = "Sin detalle, por favor consulte con el personal tecnico "; } List <UsuarioObj> sendUsuario = new List <UsuarioObj>(); sendUsuario = conBdd.obtener_usuario_por_terminal(terminal); mensaje += " Cajero :" + terminal.codigo; notificacion.enviarNotificacionUsuario(sendUsuario, mensaje, id_suceso); } datoRespuesta = ""; } } }catch (SocketException ex) { error.escritura_archivo_string(ex.StackTrace); //mensaje_error_sistema(ex.Message, Color.Red); //mensaje_error_sistema(ex.StackTrace,Color.Red); sincronico = false; clienteConectado = false; terminal.conexion = false; conBdd.actualizar_terminal(terminal); }catch (ErrorConexionTerminal ex) { //mensaje_error_sistema(ex.Message, Color.Green); sincronico = false; clienteConectado = false; terminal.conexion = false; error.escritura_archivo_string(ex.Message); conBdd.actualizar_terminal(terminal); } catch (Exception ex) { error.escritura_archivo_string(ex.StackTrace); //mensaje_error_sistema(ex.Message, Color.Red); //mensaje_error_sistema(ex.StackTrace,Color.Red); sincronico = false; clienteConectado = false; terminal.conexion = false; conBdd.actualizar_terminal(terminal); }finally { cerrar_conexion(); } }
public void cliente_servicio() { try { sincronico = true; //conBdd.abrir_conexion_base(); AlarmasObj mensajeEnvioRecep = new AlarmasObj(); mensajeEnvioRecep.id_atm = terminal.id_atm; this.comadoToATM.setPonerEnServicio(); string datoEnvio = this.comadoToATM.getTramaComandoTerminal(); string datoRespuesta = ""; //envio_string(datoEnvio); datoIn("CONEXION NUEVA TERMINAL :" + terminal.codigo); enviarDato = true; while (sincronico) { //verificarConexion(); if (enviarDato) { clienteConectado = true; datoEnvio = comadoToATM.getTramaComandoTerminal(); envio_string(datoEnvio); mensajeEnvioRecep.fecha_registro = System.DateTime.Now; mensajeEnvioRecep.envio_recepcion = 0; //cero envio, uno recibo terminalArchivo.escritura_archivo_string(">>>[" + datoEnvio.Length + "] : " + datoEnvio); enviarDato = false; datoIn(datoEnvio.Substring(2, datoEnvio.Length - 2)); mensajeEnvioRecep.mensaje = datoEnvio.Substring(2, datoEnvio.Length - 2); conBdd.insertar_alarmas(mensajeEnvioRecep); datoEnvio = ""; } datoRespuesta = recepcion_de_datos(); if (!string.IsNullOrEmpty(datoRespuesta) && datoRespuesta.Length > 2) { terminalArchivo.escritura_archivo_string("<<<[" + datoRespuesta.Length + "] : " + datoRespuesta); datoResp(datoRespuesta.Substring(2, datoRespuesta.Length - 2)); mensajeEnvioRecep.mensaje = datoRespuesta.Substring(2, datoRespuesta.Length - 2); mensajeEnvioRecep.fecha_registro = System.DateTime.Now; mensajeEnvioRecep.envio_recepcion = 1; //cero envio, uno recibo conBdd.insertar_alarmas(mensajeEnvioRecep); datoRespuesta = ""; } /*else { * comadoNDC.setSolicitarInformacionConfiguracion(); * envio_string(comadoNDC.getTramaComandoTerminal() + "");// Envio para verifficar si esta conectado el terminal * }*/ } }catch (SocketException ex) { error.escritura_archivo_string(ex.StackTrace); mensaje_error_sistema(ex.Message, Color.Red); mensaje_error_sistema(ex.StackTrace, Color.Red); sincronico = false; clienteConectado = false; }catch (ErrorConexionTerminal ex) { mensaje_error_sistema(ex.Message, Color.Green); sincronico = false; clienteConectado = false; } catch (Exception ex) { error.escritura_archivo_string(ex.StackTrace); mensaje_error_sistema(ex.Message, Color.Red); mensaje_error_sistema(ex.StackTrace, Color.Red); sincronico = false; clienteConectado = false; }finally { cerrar_conexion(); } }