You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
303 lines
7.1 KiB
303 lines
7.1 KiB
<?php |
|
/** |
|
* CodeIgniter-Aauth |
|
* |
|
* Aauth is a User Authorization Library for CodeIgniter 4.x, which aims to make |
|
* easy some essential jobs such as login, permissions and access operations. |
|
* Despite ease of use, it has also very advanced features like groupping, |
|
* access management, public access etc.. |
|
* |
|
* @package CodeIgniter-Aauth |
|
* @author Magefly Team |
|
* @copyright 2014-2017 Emre Akay |
|
* @copyright 2018 Magefly |
|
* @license https://opensource.org/licenses/MIT MIT License |
|
* @link https://github.com/magefly/CodeIgniter-Aauth |
|
*/ |
|
|
|
namespace App\Models\Aauth; |
|
|
|
use CodeIgniter\Model; |
|
use Config\Aauth as AauthConfig; |
|
|
|
/** |
|
* User Model |
|
* |
|
* @package CodeIgniter-Aauth |
|
* |
|
* @since 3.0.0 |
|
*/ |
|
class UserModel extends Model |
|
{ |
|
/** |
|
* If this model should use "softDeletes" and |
|
* simply set a flag when rows are deleted, or |
|
* do hard deletes. |
|
* |
|
* @var boolean |
|
*/ |
|
protected $useSoftDeletes = true; |
|
|
|
/** |
|
* If true, will set created_at, and updated_at |
|
* values during insert and update routines. |
|
* |
|
* @var boolean |
|
*/ |
|
protected $useTimestamps = true; |
|
|
|
/** |
|
* An array of field names that are allowed |
|
* to be set by the user in inserts/updates. |
|
* |
|
* @var array |
|
*/ |
|
protected $allowedFields = [ |
|
'email', |
|
'username', |
|
'password', |
|
]; |
|
|
|
/** |
|
* Callbacks. Each array should contain the method |
|
* names (within the model) that should be called |
|
* when those events are triggered. With the exception |
|
* of 'afterFind', all methods are passed the same |
|
* items that are given to the update/insert method. |
|
* 'afterFind' will also include the results that were found. |
|
* |
|
* @var array |
|
*/ |
|
protected $beforeInsert = ['hashPassword']; |
|
|
|
/** |
|
* Callbacks. Each array should contain the method |
|
* names (within the model) that should be called |
|
* when those events are triggered. With the exception |
|
* of 'afterFind', all methods are passed the same |
|
* items that are given to the update/insert method. |
|
* 'afterFind' will also include the results that were found. |
|
* |
|
* @var array |
|
*/ |
|
protected $beforeUpdate = ['hashPassword']; |
|
|
|
/** |
|
* Constructor |
|
*/ |
|
public function __construct($db = null, $validation = null, $config = null) |
|
{ |
|
parent::__construct(); |
|
|
|
if (is_null($config)) |
|
{ |
|
$config = new AauthConfig(); |
|
} |
|
|
|
$this->config = $config; |
|
$this->table = $this->config->dbTableUsers; |
|
$this->DBGroup = $this->config->dbProfile; |
|
|
|
$this->validationRules['email'] = 'required|valid_email|is_unique[' . $this->table . '.email]'; |
|
$this->validationRules['password'] = 'required|min_length[' . $this->config->passwordMin . ']|max_length[' . $this->config->passwordMax . ']'; |
|
$this->validationRules['username'] = 'if_exist|is_unique[' . $this->table . '.username]|regex_match[/' . $this->config->userRegexPattern . '/]'; |
|
|
|
$this->validationMessages = [ |
|
'email' => [ |
|
'is_unique' => lang('Aauth.existsAlreadyEmail'), |
|
'valid_email' => lang('Aauth.invalidEmail'), |
|
'required' => lang('Aauth.invalidEmail'), |
|
], |
|
'password' => [ |
|
'min_length' => lang('Aauth.invalidPassword'), |
|
'max_length' => lang('Aauth.invalidPassword'), |
|
'required' => lang('Aauth.invalidPassword'), |
|
], |
|
'username' => [ |
|
'is_unique' => lang('Aauth.existsAlreadyUsername'), |
|
'min_length' => lang('Aauth.invalidUsername'), |
|
'regex_match' => lang('Aauth.invalidUsername'), |
|
], |
|
]; |
|
|
|
if ($this->config->loginUseUsername) |
|
{ |
|
$this->validationRules['username'] = 'required|is_unique[' . $this->table . '.username,id,{id}]|regex_match[/' . $this->config->userRegexPattern . '/]'; |
|
|
|
$this->validationMessages['username']['required'] = lang('Aauth.requiredUsername'); |
|
} |
|
} |
|
|
|
/** |
|
* Update |
|
* |
|
*/ |
|
public function update($id = null, $data = null) |
|
{ |
|
$this->validationRules['email'] = 'if_exist|valid_email|is_unique[' . $this->table . '.email,id,{id}]'; |
|
$this->validationRules['password'] = 'if_exist|min_length[' . $this->config->passwordMin . ']|max_length[' . $this->config->passwordMax . ']'; |
|
$this->validationRules['username'] = 'if_exist|is_unique[' . $this->table . '.username,id,{id}]|regex_match[/' . $this->config->userRegexPattern . '/]'; |
|
|
|
return parent::update($id, $data); |
|
} |
|
/** |
|
* Update last login by User ID |
|
* |
|
* @param integer $userId User id |
|
* |
|
* @return boolean |
|
*/ |
|
public function updateLastLogin(int $userId) |
|
{ |
|
$builder = $this->builder(); |
|
|
|
$data['last_login'] = $this->setDate(); |
|
$data['last_activity'] = $this->setDate(); |
|
|
|
return $builder->update($data, [$this->primaryKey => $userId]); |
|
} |
|
|
|
/** |
|
* Update Last Activity by User ID |
|
* |
|
* @param integer $userId User id |
|
* |
|
* @return boolean |
|
*/ |
|
public function updateLastActivity(int $userId) |
|
{ |
|
$builder = $this->builder(); |
|
|
|
$data['last_activity'] = $this->setDate(); |
|
|
|
return $builder->update($data, [$this->primaryKey => $userId]); |
|
} |
|
|
|
/** |
|
* Update Banned by User ID |
|
* |
|
* @param integer $userId User id |
|
* @param boolean $banned Whether true to ban |
|
* |
|
* @return boolean |
|
*/ |
|
public function updateBanned(int $userId, bool $banned = false) |
|
{ |
|
$builder = $this->builder(); |
|
|
|
$data['banned'] = ($banned ? 1 : 0); |
|
|
|
return $builder->update($data, [$this->primaryKey => $userId]); |
|
} |
|
|
|
/** |
|
* Checks if user is banned |
|
* |
|
* @param integer $userId User id |
|
* |
|
* @return boolean |
|
*/ |
|
public function isBanned(int $userId) |
|
{ |
|
$builder = $this->builder(); |
|
|
|
if ($this->tempUseSoftDeletes === true) |
|
{ |
|
$builder->where($this->deletedField, 0); |
|
} |
|
|
|
$builder->select('banned'); |
|
$builder->where($this->primaryKey, $userId); |
|
$builder->where('banned', 1); |
|
|
|
if ($user = $builder->get()->getFirstRow()) |
|
{ |
|
return true; |
|
} |
|
|
|
return false; |
|
} |
|
|
|
/** |
|
* Checks if user exist by user id |
|
* |
|
* @param integer $userId User id |
|
* |
|
* @return boolean |
|
*/ |
|
public function existsById(int $userId) |
|
{ |
|
$builder = $this->builder(); |
|
|
|
if ($this->tempUseSoftDeletes === true) |
|
{ |
|
$builder->where($this->deletedField, 0); |
|
} |
|
|
|
$builder->where($this->primaryKey, $userId); |
|
return ($builder->countAllResults() ? true : false); |
|
} |
|
|
|
/** |
|
* Checks if user exist by email |
|
* |
|
* @param string $email Email address |
|
* |
|
* @return boolean |
|
*/ |
|
public function existsByEmail(string $email) |
|
{ |
|
$builder = $this->builder(); |
|
|
|
if ($this->tempUseSoftDeletes === true) |
|
{ |
|
$builder->where($this->deletedField, 0); |
|
} |
|
|
|
$builder->where('email', $email); |
|
return ($builder->countAllResults() ? true : false); |
|
} |
|
|
|
/** |
|
* Checks if user exist by username |
|
* |
|
* @param string $username Username |
|
* |
|
* @return boolean |
|
*/ |
|
public function existsByUsername(string $username) |
|
{ |
|
if (empty($username)) |
|
{ |
|
return FALSE; |
|
} |
|
|
|
$builder = $this->builder(); |
|
|
|
if ($this->tempUseSoftDeletes === TRUE) |
|
{ |
|
$builder->where($this->deletedField, 0); |
|
} |
|
|
|
$builder->where('username', $username); |
|
return ($builder->countAllResults() ? TRUE : FALSE); |
|
} |
|
|
|
/** |
|
* Hash Password Callback |
|
* |
|
* @param array $data Data array |
|
* |
|
* @return array |
|
*/ |
|
protected function hashPassword(array $data) |
|
{ |
|
if (! isset($data['data']['password'])) |
|
{ |
|
return $data; |
|
} |
|
|
|
$data['data']['password'] = password_hash($data['data']['password'], $this->config->passwordHashAlgo, $this->config->passwordHashOptions); |
|
return $data; |
|
} |
|
}
|
|
|