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