/** * @return listaResultados * @throws VerificarRGIAJFault_Exception */ public List<ResultadoRGIAJ> verificarRGIAJ() throws VerificarRGIAJFault_Exception { List<ResultadoRGIAJ> listaResultado = new ArrayList<ResultadoRGIAJ>(); List<ResultadoRGIAJ> listaErrores = new ArrayList<ResultadoRGIAJ>(); List<ResultadoRGIAJ> listaPruebas = new ArrayList<ResultadoRGIAJ>(); List<String> listaDni = new ArrayList<String>(); log.debug("Verificar RGIAJ: comienzo de la verificacion"); ValidadorJugador.setVerificacionDao(this.verificacionDao); for (Jugador jugador : jugadores) { boolean hayError = false; boolean hayPruebas = false; // Se formatean los datos del jugador ValidadorJugador.formateaDatosJugador(jugador); // Valida los datos del jugador ResultadoType validation = ValidadorJugador.validarJugador(jugador); if (validation != null && CodigosVerificacion.COD_FORMATO_INCORRECTO.equals(validation.getCodigo())) { log.debug("Formato incorrecto en Jugador: " + validation.getDescripcion()); listaErrores.add(this.generarResultadoRGIAJInvalido(jugador, validation)); hayError = true; } else if (validation != null && CodigosVerificacion.COD_CARACTERES_INVALIDOS.equals(validation.getCodigo())) { log.debug("Caracteres invalidos en jugador: " + validation.getDescripcion()); listaErrores.add(this.generarResultadoRGIAJInvalido(jugador, validation)); hayError = true; } else if (validation != null && CodigosVerificacion.COD_FALTA_CAMPO.equals(validation.getCodigo())) { log.debug("Falta campo en el nombre o apellidos: " + validation.getDescripcion()); listaErrores.add(this.generarResultadoRGIAJInvalido(jugador, validation)); hayError = true; } else if (validation != null && CodigosVerificacion.COD_FECHA_NACIMINENTO.equals(validation.getCodigo())) { log.debug( "Fecha de nacimiento del Jugador es invalida o anterior a 1900: " + validation.getDescripcion()); listaErrores.add(this.generarResultadoRGIAJInvalido(jugador, validation)); hayError = true; } if (validation != null && CodigosVerificacion.COD_NUM_SOPORTE.equals(validation.getCodigo())) { log.debug("Error de Formato en el Numero de Soporte: " + validation.getDescripcion()); listaErrores.add(this.generarResultadoRGIAJInvalido(jugador, validation)); hayError = true; } else if (validation != null && CodigosVerificacion.COD_NUM_SOPORTE_NIF.equals(validation.getCodigo())) { log.debug("Error de Numero de Soporte: " + validation.getDescripcion()); listaErrores.add(this.generarResultadoRGIAJInvalido(jugador, validation)); hayError = true; } // Si el operador utiliza datos de prueba o datos de prueba y reales // se comprueban los usuarios en la BD if (!hayError && (operador.getModeEnabled() == Constantes.OP_HABILITADO_PRU || operador.getModeEnabled() == Constantes.OP_HABILITADO_PRU_PRO)) { ResultadoRGIAJ resJugador = null; log.debug("Operador permite usuarios de prueba (modo: " + operador.getModeEnabled() + ")"); try { resJugador = this.getJugadoresTestService() .obtenerResultadoRGIAJTestWS(operador.getModeEnabled(), jugador); if (resJugador != null) { log.debug("Es usuario de prueba: " + jugador.getDni()); listaPruebas.add(resJugador); hayPruebas = true; } } catch (Exception ex) { log.error("Error consultando Resultado RGIAJ", ex); VerificarRGIAJFault fault = new VerificarRGIAJFault(); fault.setVerificarRGIAJFault(CodigosVerificacion.ERROR_INTERNO); throw new VerificarRGIAJFault_Exception(CodigosVerificacion.DESC_ERROR_INTERNO, fault); } } if (!hayError && !hayPruebas && (operador.getModeEnabled() == Constantes.OP_HABILITADO_PRU)) { // El operador es de pruebas pero el usuario es de produccion se da como invalido listaPruebas.add( this.generarResultadoRGIAJInvalido( jugador, new ResultadoType( CodigosVerificacion.COD_NO_INSCRITO_RGIAJ, CodigosVerificacion.DESC_NO_INSCRITO_RGIAJ))); hayPruebas = true; } // Si el jugador no dio error en las comprobaciones y no es de // prueba a�adimos el DNI en la lista // para la consulta de incluidos en RGIAJ if (!hayError && !hayPruebas) { log.debug("Es usuario real: " + jugador.getDni()); listaDni.add(jugador.getDni()); } } if (!listaDni.isEmpty()) { try { log.debug("Se consulta al servicio que nos indica si estan en RGIAJ"); listaResultado = this.getClienteJuegoDniService().verificarJuegoDni(listaDni); } catch (Exception e) { log.error("Error consultando estado RGIAJ " + e.getMessage(), e); VerificarRGIAJFault fault = new VerificarRGIAJFault(); fault.setVerificarRGIAJFault(CodigosVerificacion.ERROR_INTERNO); throw new VerificarRGIAJFault_Exception(CodigosVerificacion.DESC_ERROR_INTERNO, fault); } } listaResultado.addAll(listaErrores); listaResultado.addAll(listaPruebas); return listaResultado; }
/** * Validaci�n del formato de DNI-NIE, Nombre, apellidos y Fecha Nacimiento. Validaci�n de los * jugadores (SVDI o Pruebas) seg�n el estado del Operador * * @return * @throws VerificarIdentidadFault_Exception */ public List<ResultadoIdentidad> verificarIdentidad() throws VerificarIdentidadFault_Exception { List<ResultadoIdentidad> listaResultado = new ArrayList<ResultadoIdentidad>(); List<ResultadoIdentidad> listaErrores = new ArrayList<ResultadoIdentidad>(); List<ResultadoIdentidad> listaPruebas = new ArrayList<ResultadoIdentidad>(); ResultadoIdentidad resIdentidad = null; log.debug("Verificar Identidad: comienzo de la verificacion"); ValidadorJugador.setVerificacionDao(this.verificacionDao); for (Jugador jugador : jugadores) { boolean hayError = false; boolean hayPruebas = false; // Formatear Datos ValidadorJugador.formateaDatosJugador(jugador); // Valida los datos del jugador ResultadoType validation = ValidadorJugador.validarJugador(jugador); if (validation != null && CodigosVerificacion.COD_FORMATO_INCORRECTO.equals(validation.getCodigo())) { log.debug("Error Validando Jugador: " + validation.getDescripcion()); listaErrores.add(this.generarResultadoIdentidadInvalido(jugador, validation)); hayError = true; } else if (validation != null && CodigosVerificacion.COD_CARACTERES_INVALIDOS.equals(validation.getCodigo())) { log.debug("Error Validando Jugador: " + validation.getDescripcion()); listaErrores.add(this.generarResultadoIdentidadInvalido(jugador, validation)); hayError = true; } else if (validation != null && CodigosVerificacion.COD_FALTA_CAMPO.equals(validation.getCodigo())) { log.debug("Falta campo en el nombre o apellidos: " + validation.getDescripcion()); listaErrores.add(this.generarResultadoIdentidadInvalido(jugador, validation)); hayError = true; } else if (validation != null && CodigosVerificacion.COD_FECHA_NACIMINENTO.equals(validation.getCodigo())) { log.debug( "Fecha de nacimiento del Jugador es inválida o anterior a 1900: " + validation.getDescripcion()); listaErrores.add(this.generarResultadoIdentidadInvalido(jugador, validation)); hayError = true; } else if (validation != null && CodigosVerificacion.COD_NUM_SOPORTE.equals(validation.getCodigo())) { log.debug("Error de Formato en el Numero de Soporte: " + validation.getDescripcion()); listaErrores.add(this.generarResultadoIdentidadInvalido(jugador, validation)); hayError = true; } else if (validation != null && CodigosVerificacion.COD_NUM_SOPORTE_NIF.equals(validation.getCodigo())) { log.debug("Error de Numero de Soporte: " + validation.getDescripcion()); listaErrores.add(this.generarResultadoIdentidadInvalido(jugador, validation)); hayError = true; } // Si el operador utiliza datos de prueba o datos de prueba y reales // se comprueban los usuarios en la BD if (!hayError && ((operador.getModeEnabled() == Constantes.OP_HABILITADO_PRU) || (operador.getModeEnabled() == Constantes.OP_HABILITADO_PRU_PRO))) { ResultadoIdentidad resJugador = null; log.debug("Operador permite usuarios de prueba (modo: " + operador.getModeEnabled() + ")"); try { resJugador = this.getJugadoresTestService().obtenerResultadoIdentidadTestWS(operador, jugador); if (resJugador != null) { log.debug("Es usuario de prueba: " + jugador.getDni()); listaPruebas.add(resJugador); hayPruebas = true; } } catch (Exception ex) { log.error("Error llamada servicio : " + ex); VerificarIdentidadFault fault = new VerificarIdentidadFault(); fault.setVerificarIdentidadFault(CodigosVerificacion.ERROR_INTERNO); throw new VerificarIdentidadFault_Exception( CodigosVerificacion.DESC_ERROR_INTERNO, fault); } } if (!hayError && !hayPruebas && (operador.getModeEnabled() == Constantes.OP_HABILITADO_PRU)) { // El operador es de pruebas pero el usuario es de produccion se da como invalido listaPruebas.add( this.generarResultadoIdentidadInvalido( jugador, new ResultadoType( CodigosVerificacion.COD_IDENTIDAD_INCORRECTA_TEST, CodigosVerificacion.DESC_IDENTIDAD_INCORRECTA))); hayPruebas = true; } resIdentidad = new ResultadoIdentidad(); // Si el jugador no dio error en las comprobaciones y no es de // prueba se verifica su identidad if (!hayError && !hayPruebas) { log.debug("Es usuario real: " + jugador.getDni()); // S�lo buscamos en cach� si no se cumple que est� activado el // debug y el DNI est� en la tabla de no cachear boolean debugActived = this.getVerificacionDao() .getValorPropiedad(Constantes.PROP_MODO_DEBUG_IDENTIDAD) .equals("true"); if (!debugActived || (debugActived && this.getGestionJugadoresService().esCacheable(jugador.getDni()))) { log.debug("Se busca en cach\u00E9"); // Buscar primero en la cach� String codResultadoBusquedaCache = null; try { codResultadoBusquedaCache = this.getGestionJugadoresService() .identidadJugadorCache( jugador.getDni(), jugador.getFechaNacimiento(), jugador.getNombre(), jugador.getApellido1(), jugador.getApellido2(), jugador.getNumSoporte()); } catch (Exception e) { log.error("Error verificando Identidad " + e.getMessage(), e); VerificarIdentidadFault fault = new VerificarIdentidadFault(); fault.setVerificarIdentidadFault(CodigosVerificacion.ERROR_INTERNO); throw new VerificarIdentidadFault_Exception( CodigosVerificacion.DESC_ERROR_INTERNO, fault); } // Si existe en cach� se devuelve el valor if (codResultadoBusquedaCache != null) { log.debug("Est\u00E1 en cach\u00E9"); resIdentidad.setDni(jugador.getDni()); resIdentidad.setResultadoIdentidad(new ResultadoType()); resIdentidad.getResultadoIdentidad().setCodigo(codResultadoBusquedaCache); resIdentidad .getResultadoIdentidad() .setDescripcion(CodigosVerificacion.getDescripcion(codResultadoBusquedaCache)); // Si no existe en cach� se busca en el servicio de la // polic�a } else { log.debug("No est\u00E1 en cach\u00E9, se consulta al servicio de la policia"); CodigoEstadoSCSP codigoResultado = null; try { codigoResultado = this.getClienteSCSPService() .verificarIdentidad( jugador.getDni(), jugador.getNumSoporte(), jugador.getNombre(), jugador.getApellido1(), jugador.getApellido2(), jugador.getFechaNacimiento()); } catch (Exception e) { log.error("Error verificando Identidad con cliente SCP " + e.getMessage(), e); codigoResultado = new CodigoEstadoSCSP(); codigoResultado.setCodigo(CodigosVerificacion.COD_NO_VERIFICACION_IDENTIDAD); codigoResultado.setDescripcion(CodigosVerificacion.DESC_NO_VERIFICACION_IDENTIDAD); // throw new VerificarIdentidadFault_Exception(e.getMessage(),e); } resIdentidad.setDni(jugador.getDni()); resIdentidad.setResultadoIdentidad(new ResultadoType()); resIdentidad.getResultadoIdentidad().setCodigo(codigoResultado.getCodigo()); resIdentidad.getResultadoIdentidad().setDescripcion(codigoResultado.getDescripcion()); } } else { log.debug("No se debe consultar cach\u00E9, se consulta al servicio de la policia"); // Se comprueba la identidad llamando al servicio CodigoEstadoSCSP codigoResultado = null; try { codigoResultado = this.getClienteSCSPService() .verificarIdentidad( jugador.getDni(), jugador.getNumSoporte(), jugador.getNombre(), jugador.getApellido1(), jugador.getApellido2(), jugador.getFechaNacimiento()); } catch (Exception e) { // TODO Auto-generated catch block log.error("Error verificando Identidad " + e.getMessage(), e); codigoResultado = new CodigoEstadoSCSP(); codigoResultado.setCodigo(CodigosVerificacion.COD_NO_VERIFICACION_IDENTIDAD); codigoResultado.setDescripcion(CodigosVerificacion.DESC_NO_VERIFICACION_IDENTIDAD); } resIdentidad.setDni(jugador.getDni()); resIdentidad.setResultadoIdentidad(new ResultadoType()); resIdentidad.getResultadoIdentidad().setCodigo(codigoResultado.getCodigo()); resIdentidad.getResultadoIdentidad().setDescripcion(codigoResultado.getDescripcion()); } listaResultado.add(resIdentidad); } } listaResultado.addAll(listaErrores); listaResultado.addAll(listaPruebas); return listaResultado; }