EN · DE · RU · FR · ES

#504 : LdapSambaAccountsUtils.java

projectforge-business/src/main/java/org/projectforge/business/ldap/LdapSambaAccountsUtils.java Type : Java · Rôle : Intégration LDAP · Source : projectforge-business/src/main/java/org/projectforge/business/ldap/LdapSambaAccountsUtils.java 141 lignes · 70 code · 60 commentaires · 11 vides
Méthodes utilitaires statiques pour LdapSambaAccounts. Ensemble de fonctions pures sans effets secondaires, fournissant des opérations d’assistance courantes.

Structure du code

Paquetage : org.projectforge.business.ldap

Classes : LdapSambaAccountsUtils

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

Champs (2) : ldapService, userGroupCache

Importations : 6 paquetages

Code source (abrégé)

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;

  /**
   * Récupère tous les numéros uid donnés de tous les utilisateurs ProjectForge, y compris les utilisateurs supprimés,
   * et obtient le numéro libre le plus élevé suivant. Le numéro est 1000 si aucun numéro uid (avec une valeur supérieure à 999) n’est trouvé.
   */
  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;
  }

  /**
   * Pour éviter les doublons de uidNumbers.
   *
   * @param currentUser
   * @param sambaSIDNumber
   * @return Retourne true si un utilisateur (y compris les utilisateurs supprimés) autre que l’utilisateur donné possède le uidNumber donné, sinon false.
   */
  public boolean isGivenNumberFree(final PFUserDO currentUser, final Integer sambaSIDNumber) {
    return isGivenNumberFree(currentUser.getId(), sambaSIDNumber);
  }

  /**
   * Pour éviter les doublons de uidNumbers.
   *
   * @param currentUserId
   * @param sambaSIDNumber
   * @return Retourne true si un utilisateur (y compris les utilisateurs supprimés) autre que l’utilisateur donné possède le uidNumber donné, sinon false.
   */
  public boolean isGivenNumberFree(final Long currentUserId, final Integer sambaSIDNumber) {
    if (sambaSIDNumber == null) {
      // Rien à vérifier.
      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)) {
        // L’utilisateur actuel peut déjà avoir le sambaSIDNumber donné, donc ignorer cette entrée.
        continue;
      }
      if (ldapUserValues != null
          && ldapUserValues.getSambaSIDNumber() != null
          && ldapUserValues.getSambaSIDNumber().intValue() == sambaSIDNumber) {
        // Le numéro n’est pas libre.
        log.info("Le getSambaSIDNumber (compte samba) '" + sambaSIDNumber + "' est déjà occupé par l’utilisateur : " + user);
        return false;
      }
    }
    return true;
  }

  /**
   * Définit le prochain SambaSID libre ou, s’il est libre et donné, le même identifiant que le posix UID.
   *
   * @param ldapUserValues
   * @param user
   */
  public void setDefaultValues(final LdapUserValues ldapUserValues, final PFUserDO user) {
    setDefaultValues(ldapUserValues, user.getId());
  }

  /**
   * Définit le prochain SambaSID libre ou, s’il est libre et donné, le même identifiant que le posix UID.
   *
   * @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());
    }
  }
}

Historique Git

868d6abb7 2025 -> 2026
63081666f En-têtes des fichiers source : 2024 -> 2025.
4c04cfd65 CHANGEMENT-MAJEUR ! Migration des identifiants integer vers Long (y compris les clés étrangères, etc.)
b6092df09 Copyright 2023 -> 2024
ab45d51fa Copyright 2001-2022 -> 2001-2023.