user->getById($user_id); } public function getUserByName($username) { return $this->user->getByUsername($username); } public function getAllUsers() { return $this->user->getAll(); } public function removeUser($user_id) { return $this->user->remove($user_id); } public function disableUser($user_id) { return $this->user->disable($user_id); } public function enableUser($user_id) { return $this->user->enable($user_id); } public function isActiveUser($user_id) { return $this->user->isActive($user_id); } public function createUser($username, $password, $name = '', $email = '', $role = Role::APP_USER) { $values = array( 'username' => $username, 'password' => $password, 'confirmation' => $password, 'name' => $name, 'email' => $email, 'role' => $role, ); list($valid, ) = $this->userValidator->validateCreation($values); return $valid ? $this->user->create($values) : false; } /** * Create LDAP user in the database * * Only "anonymous" and "proxy" LDAP authentication are supported by this method * * User information will be fetched from the LDAP server * * @access public * @param string $username * @return bool|int */ public function createLdapUser($username) { if (LDAP_BIND_TYPE === 'user') { $this->logger->error('LDAP authentication "user" is not supported by this API call'); return false; } try { $ldap = LdapClient::connect(); $ldap->setLogger($this->logger); $user = LdapUser::getUser($ldap, $username); if ($user === null) { $this->logger->info('User not found in LDAP server'); return false; } if ($user->getUsername() === '') { throw new LogicException('Username not found in LDAP profile, check the parameter LDAP_USER_ATTRIBUTE_USERNAME'); } $values = array( 'username' => $user->getUsername(), 'name' => $user->getName(), 'email' => $user->getEmail(), 'role' => $user->getRole(), 'is_ldap_user' => 1, ); return $this->user->create($values); } catch (LdapException $e) { $this->logger->error($e->getMessage()); return false; } } public function updateUser($id, $username = null, $name = null, $email = null, $role = null) { $values = array( 'id' => $id, 'username' => $username, 'name' => $name, 'email' => $email, 'role' => $role, ); foreach ($values as $key => $value) { if (is_null($value)) { unset($values[$key]); } } list($valid, ) = $this->userValidator->validateApiModification($values); return $valid && $this->user->update($values); } }