*/ class LSgroup extends LSldapObject { var $userObjectType = 'LSpeople'; var $memberAttr = 'uniqueMember'; var $memberAttrValue = 'dn'; /* ========== Members ========== */ /** * Retourne la valeur clef d'un membre * * @param LSldapObject $object Un object utilisateur * * @return Mixed La valeur clef d'un membre **/ public function getMemberKeyValue($object) { return $this -> getObjectKeyValueInRelation($object,$this -> userObjectType,$this -> memberAttrValue); } /** * Retourne la liste des groupes pour utilisateur * * Retourne un tableau de LSgroup correspondant aux groupes * auxquels appartient un utilisateur * * @param LSldapObject $userObject Un object user (type : $this -> userObjectType) * * @return array Les groupes de l'utilisateur **/ public function listUserGroups($userObject) { return $this -> listObjectsInRelation($userObject,$this -> memberAttr,$this -> userObjectType,$this -> memberAttrValue); } /** * Ajoute un utilisateur au groupe * * @param LSldapObject $object Un object user ($this -> userObjectType) : l'utilisateur à ajouter * * @return boolean true si l'utilisateur à été ajouté, False sinon **/ public function addOneMember($object) { return $this -> addOneObjectInRelation($object,$this -> memberAttr, $this -> userObjectType,$this -> memberAttrValue,'canEditGroupRelation'); } /** * Supprime un utilisateur du groupe * * @param LSldapObject $object Un object (type : $this -> userObjectType) : l'utilisateur à supprimer * * @return boolean true si l'utilisateur à été supprimé, False sinon **/ public function deleteOneMember($object) { return $this -> deleteOneObjectInRelation($object,$this -> memberAttr,$this -> userObjectType,$this -> memberAttrValue,'canEditGroupRelation'); } /** * Renome un utilisateur du groupe * * @param LSldapObject $object Un object (type : $this -> userObjectType) : l'utilisateur à renomer * @param string $oldDn L'ancien DN de l'utilisateur * * @return boolean True en cas de succès, False sinon */ public function renameOneMember($object,$oldDn) { return $this -> renameOneObjectInRelation($object,$oldDn,$this -> memberAttr,$this -> userObjectType,$this -> memberAttrValue); } /** * Met à jour les groupes d'un utilisateur * * @param Mixed $object Un object (type : $this -> userObjectType) : l'utilisateur * @param array $listDns Array(string) Un tableau des DNs des groupes de l'utilisateur * * @return boolean true si tout c'est bien passé, False sinon **/ public function updateUserGroups($object,$listDns) { return $this -> updateObjectsInRelation($object,$listDns,$this -> memberAttr,$this -> userObjectType,$this -> memberAttrValue,'canEditGroupRelation'); } /** * Test si l'utilisateur peut d'editer la relation avec ce groupe * * @return boolean true si tout l'utilisateur peut éditer la relation, False sinon **/ public function canEditGroupRelation($dn=NULL) { if (!$dn) { $dn=$this -> dn; } return LSsession :: canEdit($this -> type_name,$this -> dn,$this -> memberAttr); } }