EN · DE · RU · FR · ES

#504: LdapSambaAccountsUtils.java

projectforge-business/src/main/java/org/projectforge/business/ldap/LdapSambaAccountsUtils.java Tipo: Java · Rol: Integración LDAP · Fuente: projectforge-business/src/main/java/org/projectforge/business/ldap/LdapSambaAccountsUtils.java 141 líneas · 70 código · 60 comentarios · 11 en blanco
Métodos de utilidad estáticos para LdapSambaAccounts. Colección de funciones puras sin efectos secundarios, que proporcionan operaciones auxiliares comunes.

Estructura del código

Paquete: org.projectforge.business.ldap

Clases: LdapSambaAccountsUtils

Métodos (5): getNextFreeSambaSIDNumber, isGivenNumberFree, isGivenNumberFree, setDefaultValues, setDefaultValues

Campos (2): ldapService, userGroupCache

Importaciones: 6 paquetes

Código fuente (resumido)

package org.projectforge.business.ldap;

import org.projectforge.business.user.UserGroupCache;
import org.projectforge.framework.persistence.user.entities.PFUserDO;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.Collection;
import java.util.Objects;

/**
 * @author Kai Reinhard (k.reinhard@micromata.de)
 */
@Service
public class LdapSambaAccountsUtils {
  private static final org.slf4j.Logger log = org.slf4j.LoggerFactory.getLogger(LdapSambaAccountsUtils.class);

  @Autowired
  private LdapService ldapService;

  @Autowired
  private UserGroupCache userGroupCache;

  /**
   * Obtiene todos los números uid dados de todos los usuarios de ProjectForge, incluidos los usuarios eliminados,
   * y obtiene el siguiente número más alto y libre. El número es 1000 si no se encuentra ningún número uid
   * (con un valor mayor a 999).
   */
  public int getNextFreeSambaSIDNumber() {
    final Collection<PFUserDO> allUsers = userGroupCache.getAllUsers();
    int currentMaxNumber = 999;
    for (final PFUserDO user : allUsers) {
      final LdapUserValues ldapUserValues = PFUserDOConverter.readLdapUserValues(user.getLdapValues());
      if (ldapUserValues == null) {
        continue;
      }
      if (ldapUserValues.getSambaSIDNumber() != null
          && ldapUserValues.getSambaSIDNumber() > currentMaxNumber) {
        currentMaxNumber = ldapUserValues.getUidNumber();
      }
    }
    return currentMaxNumber + 1;
  }

  /**
   * Para evitar números uid duplicados.
   *
   * @param currentUser
   * @param sambaSIDNumber
   * @return Devuelve true si algún usuario (incluidos los eliminados) que no sea el usuario dado tiene el número uid
   *         especificado; de lo contrario, false.
   */
  public boolean isGivenNumberFree(final PFUserDO currentUser, final Integer sambaSIDNumber) {
    return isGivenNumberFree(currentUser.getId(), sambaSIDNumber);
  }

  /**
   * Para evitar números uid duplicados.
   *
   * @param currentUserId
   * @param sambaSIDNumber
   * @return Devuelve true si algún usuario (incluidos los eliminados) que no sea el usuario dado tiene el número uid
   *         especificado; de lo contrario, false.
   */
  public boolean isGivenNumberFree(final Long currentUserId, final Integer sambaSIDNumber) {
    if (sambaSIDNumber == null) {
      // Nada que verificar.
      return true;
    }
    final Collection<PFUserDO> allUsers = userGroupCache.getAllUsers();
    for (final PFUserDO user : allUsers) {
      final LdapUserValues ldapUserValues = PFUserDOConverter.readLdapUserValues(user.getLdapValues());
      if (Objects.equals(user.getId(), currentUserId)) {
        // El usuario actual ya puede tener el sambaSIDNumber dado, así que ignoramos esta entrada.
        continue;
      }
      if (ldapUserValues != null
          && ldapUserValues.getSambaSIDNumber() != null
          && ldapUserValues.getSambaSIDNumber().intValue() == sambaSIDNumber) {
        // El número no está libre.
        log.info("El getSambaSIDNumber (cuenta samba) '" + sambaSIDNumber + "' ya está ocupado por el usuario: " + user);
        return false;
      }
    }
    return true;
  }

  /**
   * Establece el siguiente SambaSID libre o, si está libre y se proporciona, el mismo ID que el UID de POSIX.
   *
   * @param ldapUserValues
   * @param user
   */
  public void setDefaultValues(final LdapUserValues ldapUserValues, final PFUserDO user) {
    setDefaultValues(ldapUserValues, user.getId());
  }

  /**
   * Establece el siguiente SambaSID libre o, si está libre y se proporciona, el mismo ID que el UID de POSIX.
   *
   * @param ldapUserValues
   * @param userId
   */
  public void setDefaultValues(final LdapUserValues ldapUserValues, final Long userId) {
    final LdapConfig ldapConfig = ldapService.getLdapConfig();
    LdapSambaAccountsConfig ldapSambaAccountsConfig = ldapConfig != null ? ldapConfig.getSambaAccountsConfig() : null;
    if (ldapSambaAccountsConfig == null) {
      ldapSambaAccountsConfig = new LdapSambaAccountsConfig();
    }
    if (ldapUserValues.getUidNumber() != null && isGivenNumberFree(userId, ldapUserValues.getUidNumber())) {
      ldapUserValues.setSambaSIDNumber(ldapUserValues.getUidNumber());
    } else {
      ldapUserValues.setSambaSIDNumber(getNextFreeSambaSIDNumber());
    }
    if (ldapSambaAccountsConfig.getDefaultSambaPrimaryGroupSID() != null) {
      ldapUserValues.setSambaPrimaryGroupSIDNumber(ldapSambaAccountsConfig.getDefaultSambaPrimaryGroupSID());
    }
  }
}

Historial de Git

868d6abb7 2025 -> 2026
63081666f Encabezados de archivos fuente: 2024-> 2025.
4c04cfd65 CAMBIO-MAYOR! Migración de identificadores integer a Long (incluyendo claves foráneas, etc.)
b6092df09 Copyright 2023 -> 2024
ab45d51fa Copyright 2001-2022 -> 2001-2023.