LdapSambaAccountsUtils.javaPaquetage : org.projectforge.business.ldap
Classes : LdapSambaAccountsUtils
Méthodes (5) : getNextFreeSambaSIDNumber, isGivenNumberFree, isGivenNumberFree, setDefaultValues, setDefaultValues
Champs (2) : ldapService, userGroupCache
Importations : 6 paquetages
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());
}
}
}
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.