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.

298 lines
7.2 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 grouping,
* access management, public access etc..
*
* @package CodeIgniter-Aauth
* @author Emre Akay
* @author Raphael "REJack" Jackstadt
* @copyright 2014-2019 Emre Akay
* @license https://opensource.org/licenses/MIT MIT License
* @link https://github.com/emreakay/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 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->tempUseSoftDeletes = $this->config->dbSoftDeleteUsers;
$this->tempReturnType = $this->config->dbReturnType;
$this->validationRules['email'] = 'required|valid_email|is_unique[' . $this->table . '.email,id,{id}]';
$this->validationRules['password'] = 'required|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 . '/]';
$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();
$request = \Config\Services::request();
$data['last_login'] = $this->setDate();
$data['last_activity'] = $this->setDate();
$data['last_ip_address'] = $request->getIPAddress();
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 ($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;
}
}