UsersTable.php 3.48 KB
<?php
namespace App\Model\Table;

use App\Model\Entity\User;
use Cake\ORM\Query;
use Cake\ORM\RulesChecker;
use Cake\ORM\Table;
use Cake\Validation\Validator;
use Cake\ORM\TableRegistry;

/**
 * Users Model
 *
 * @property \Cake\ORM\Association\BelongsTo $GroupesMetiers
 */
class UsersTable extends AppTable
{

    /**
     * Initialize method
     *
     * @param array $config The configuration for the Table.
     * @return void
     */
    public function initialize(array $config)
    {
        parent::initialize($config);

        $this->table('users');
        $this->displayField('id');
        $this->primaryKey('id');

        $this->belongsTo('GroupesMetiers', [
            'foreignKey' => 'groupes_metier_id'
        ]);
    }

    /**
     * Default validation rules.
     *
     * @param \Cake\Validation\Validator $validator Validator instance.
     * @return \Cake\Validation\Validator
     */
    public function validationDefault(Validator $validator)
    {
        $validator
            ->integer('id')
            ->allowEmpty('id', 'create');

        $validator
            ->notEmpty('nom', 'Un nom est nécessaire')
            ->add('nom', 'valid', ['rule' => ['check_string'], 'message' => 'Le champ doit être valide.', 'provider' => 'table']);

        $validator
            ->notEmpty('username', 'Un login est nécessaire')
            ->add('username', 'valid', ['rule' => ['check_string'], 'message' => 'Le champ doit être valide.', 'provider' => 'table'])
            ->add('username', 'unique', ['rule' => 'validateUnique', 'provider' => 'table']);

        $validator
            ->allowEmpty('password');

        $validator
            ->email('email')
            ->notEmpty('email', 'Un adresse mail est nécessaire');

        $validator
            ->notEmpty('role', 'Un rôle est nécessaire')
            ->add('role', 'inList', [
            		'rule' => ['inList', ['Super Administrateur', 'Administration Plus', 'Administration', 'Responsable', 'Utilisateur']],
            		'message' => 'Merci de rentrer un role valide'
            ]);

        return $validator;
    }

    /**
     * Returns a rules checker object that will be used for validating
     * application integrity.
     *
     * @param \Cake\ORM\RulesChecker $rules The rules object to be modified.
     * @return \Cake\ORM\RulesChecker
     */
    public function buildRules(RulesChecker $rules)
    {
        $rules->add($rules->isUnique(['username']));
        $rules->add($rules->isUnique(['email']));
        $rules->add($rules->existsIn(['groupes_metier_id'], 'GroupesMetiers'));
        return $rules;
    }
    
    // $ldapName = login
    public function getEmailFromLdapName($ldapName) {
    	if(isset($ldapName)) {
    		$attributes = TableRegistry::get('LdapConnections')->getUserAttributes($ldapName);
    		@$mail = $attributes[0]['mail'][0];
    		return $mail;
    	}
    }
    
    public function getLdapUsers() {
    	$allUsers = TableRegistry::get('LdapConnections')->getAllLdapUsers();

    	$ldapUsers = [];
    	$usersName = [];
    	foreach($allUsers as $user)
    		if(!empty($user['sn'][0]) && !empty($user['givenname'][0]))
    			array_push($usersName, $user['sn'][0] . ' ' . $user['givenname'][0]);
    
    		return $ldapUsers;
    }
    
    
    
    function beforeSave($event, $entity, $options) {

    	if (!empty($entity->get('newname')) && !empty($entity->get('newgivenname'))) {
    		$entity->set('nom', $entity->get('newname').' '.$entity->get('newgivenname'));
    	}
    	return true;
    }
    
}