2014-07-23 16:50:34 +02:00
|
|
|
<?php
|
|
|
|
|
2016-07-19 20:28:11 +02:00
|
|
|
namespace PHPCensor\Service;
|
2014-07-23 16:50:34 +02:00
|
|
|
|
2016-07-19 20:28:11 +02:00
|
|
|
use PHPCensor\Model\User;
|
|
|
|
use PHPCensor\Store\UserStore;
|
2014-07-23 16:50:34 +02:00
|
|
|
|
2014-12-08 12:25:33 +01:00
|
|
|
/**
|
|
|
|
* The user service handles the creation, modification and deletion of users.
|
|
|
|
*/
|
2014-07-23 16:50:34 +02:00
|
|
|
class UserService
|
|
|
|
{
|
|
|
|
/**
|
2016-07-21 19:20:59 +02:00
|
|
|
* @var \PHPCensor\Store\UserStore
|
2014-07-23 16:50:34 +02:00
|
|
|
*/
|
|
|
|
protected $store;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param UserStore $store
|
|
|
|
*/
|
|
|
|
public function __construct(UserStore $store)
|
|
|
|
{
|
|
|
|
$this->store = $store;
|
|
|
|
}
|
|
|
|
|
2014-12-08 12:25:33 +01:00
|
|
|
/**
|
2017-10-21 10:51:05 +02:00
|
|
|
* Create a new user.
|
2017-11-05 15:48:36 +01:00
|
|
|
*
|
|
|
|
* @param string $name
|
|
|
|
* @param string $email
|
|
|
|
* @param string $providerKey
|
2018-03-09 19:00:53 +01:00
|
|
|
* @param array $providerData
|
2017-11-05 15:48:36 +01:00
|
|
|
* @param string $password
|
|
|
|
* @param boolean $isAdmin
|
|
|
|
*
|
2017-01-03 19:22:58 +01:00
|
|
|
* @return User
|
2014-12-08 12:25:33 +01:00
|
|
|
*/
|
2017-02-04 18:44:55 +01:00
|
|
|
public function createUser($name, $email, $providerKey, $providerData, $password, $isAdmin = false)
|
2014-07-23 16:50:34 +02:00
|
|
|
{
|
|
|
|
$user = new User();
|
|
|
|
$user->setName($name);
|
2017-02-04 18:44:55 +01:00
|
|
|
$user->setEmail($email);
|
2014-07-23 16:50:34 +02:00
|
|
|
$user->setHash(password_hash($password, PASSWORD_DEFAULT));
|
2016-07-17 12:55:42 +02:00
|
|
|
$user->setProviderKey($providerKey);
|
|
|
|
$user->setProviderData($providerData);
|
2018-03-09 19:00:53 +01:00
|
|
|
$user->setIsAdmin($isAdmin);
|
2016-07-17 12:55:42 +02:00
|
|
|
|
|
|
|
return $this->store->save($user);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-12-08 12:25:33 +01:00
|
|
|
* Update a user.
|
2017-11-05 15:48:36 +01:00
|
|
|
*
|
2017-01-03 19:22:58 +01:00
|
|
|
* @param User $user
|
|
|
|
* @param string $name
|
|
|
|
* @param string $emailAddress
|
|
|
|
* @param string $password
|
2017-11-05 15:48:36 +01:00
|
|
|
* @param boolean $isAdmin
|
2017-01-03 19:22:58 +01:00
|
|
|
* @param string $language
|
|
|
|
* @param integer $perPage
|
2017-11-05 15:48:36 +01:00
|
|
|
*
|
2017-01-03 19:22:58 +01:00
|
|
|
* @return User
|
2014-12-08 12:25:33 +01:00
|
|
|
*/
|
2017-01-03 19:22:58 +01:00
|
|
|
public function updateUser(User $user, $name, $emailAddress, $password = null, $isAdmin = null, $language = null, $perPage = null)
|
2014-07-23 16:50:34 +02:00
|
|
|
{
|
|
|
|
$user->setName($name);
|
|
|
|
$user->setEmail($emailAddress);
|
|
|
|
|
|
|
|
if (!empty($password)) {
|
|
|
|
$user->setHash(password_hash($password, PASSWORD_DEFAULT));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!is_null($isAdmin)) {
|
2018-03-09 19:00:53 +01:00
|
|
|
$user->setIsAdmin($isAdmin);
|
2014-07-23 16:50:34 +02:00
|
|
|
}
|
2018-03-09 19:00:53 +01:00
|
|
|
|
2017-01-03 19:22:58 +01:00
|
|
|
$user->setLanguage($language);
|
|
|
|
$user->setPerPage($perPage);
|
|
|
|
|
2014-07-23 16:50:34 +02:00
|
|
|
return $this->store->save($user);
|
|
|
|
}
|
|
|
|
|
2014-12-08 12:25:33 +01:00
|
|
|
/**
|
|
|
|
* Delete a user.
|
2017-11-05 15:48:36 +01:00
|
|
|
*
|
2014-12-08 12:25:33 +01:00
|
|
|
* @param User $user
|
2017-11-05 15:48:36 +01:00
|
|
|
*
|
2014-12-08 12:25:33 +01:00
|
|
|
* @return bool
|
|
|
|
*/
|
2014-07-23 16:50:34 +02:00
|
|
|
public function deleteUser(User $user)
|
|
|
|
{
|
|
|
|
return $this->store->delete($user);
|
|
|
|
}
|
|
|
|
}
|