/** Se envia como DNI el valor XXXXXXXXX y COD=CODXXX Recarga la Tabla de configuracion */
 public List<ResultadoIdentidad> reloadConf() throws VerificarIdentidadFault_Exception {
   if (jugadores != null)
     for (Jugador jugador : jugadores) {
       if (jugador != null
           && jugador.getDni() != null
           && jugador.getDni().equalsIgnoreCase(Constantes.DNI_CHEQUEO_RECARGA_CONF)) {
         if (verificacionDao != null) {
           List<ResultadoIdentidad> result = new ArrayList<ResultadoIdentidad>();
           verificacionDao.reloadCacheConfiguraciones();
           log.info("Recargada la Tabla de Configuracion");
           // se rellenan valores a esperar
           ResultadoIdentidad value = new ResultadoIdentidad();
           value.setDni(jugador.getDni());
           ResultadoType type = new ResultadoType();
           type.setCodigo("CODXXX");
           type.setDescripcion("Error de Formato");
           value.setResultadoIdentidad(type);
           result.add(value);
           return result;
         }
       }
       break;
     }
   return null;
 }
  /**
   * @param jugador
   * @param codError
   * @return resultadoIdentidad
   */
  private ResultadoIdentidad generarResultadoIdentidadInvalido(
      Jugador jugador, ResultadoType type) {
    ResultadoIdentidad res = new ResultadoIdentidad();
    res.setDni(jugador.getDni());

    res.setResultadoIdentidad(type);

    return res;
  }
  /**
   * 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;
  }