Browse Source

updated models (LoginAttemptModel & UserModel) & added UserVariableModel

v3-dev
REJack 7 years ago
parent
commit
2fe41c9282
  1. 17
      Models/LoginAttemptModel.php
  2. 67
      Models/UserModel.php
  3. 38
      Models/UserVariableModel.php

17
Models/LoginAttemptModel.php

@ -5,7 +5,6 @@ use Magefly\Aauth\Config\Aauth as AauthConfig;
class LoginAttemptModel extends Model class LoginAttemptModel extends Model
{ {
protected $useSoftDeletes = false;
protected $useTimestamps = true; protected $useTimestamps = true;
protected $createdField = 'created_datetime'; protected $createdField = 'created_datetime';
protected $updatedField = 'updated_datetime'; protected $updatedField = 'updated_datetime';
@ -22,7 +21,6 @@ class LoginAttemptModel extends Model
public function update($id = null, $data = null) public function update($id = null, $data = null)
{ {
$request = \Config\Services::request(); $request = \Config\Services::request();
$builder = $this->builder(); $builder = $this->builder();
$ip_address = $request->getIPAddress(); $ip_address = $request->getIPAddress();
$builder->where('ip_address', $ip_address); $builder->where('ip_address', $ip_address);
@ -45,7 +43,7 @@ class LoginAttemptModel extends Model
$data[$this->updatedField] = $this->setDate(); $data[$this->updatedField] = $this->setDate();
$builder->update($data, array('id' => $row->id)); $builder->update($data, array('id' => $row->id));
if ( $data['count'] > $this->config->loginAttemptLimit) if ($data['count'] > $this->config->loginAttemptLimit)
{ {
return false; return false;
} }
@ -59,11 +57,11 @@ class LoginAttemptModel extends Model
public function get() public function get()
{ {
$request = \Config\Services::request(); $request = \Config\Services::request();
$builder = $this->builder(); $builder = $this->builder();
$ip_address = $request->getIPAddress(); $ip_address = $request->getIPAddress();
$builder->where('ip_address', $ip_address); $builder->where('ip_address', $ip_address);
$builder->where('updated_datetime >=', date("Y-m-d H:i:s", strtotime("-".$this->config->loginAttemptLimitTimePeriod))); $builder->where('updated_datetime >=', date("Y-m-d H:i:s", strtotime("-".$this->config->loginAttemptLimitTimePeriod)));
if ($builder->countAllResults() != 0) if ($builder->countAllResults() != 0)
{ {
$row = $builder->get()->getFirstRow(); $row = $builder->get()->getFirstRow();
@ -74,4 +72,15 @@ class LoginAttemptModel extends Model
return 0; return 0;
} }
} }
public function delete($id = null, $purge = false)
{
$request = \Config\Services::request();
$builder = $this->builder();
$ip_address = $request->getIPAddress();
$builder->where('ip_address', $ip_address);
$builder->where('updated_datetime >=', date("Y-m-d H:i:s", strtotime("-".$this->config->loginAttemptLimitTimePeriod)));
return $builder->delete();
}
} }

67
Models/UserModel.php

@ -44,7 +44,25 @@ class UserModel extends Model
} }
} }
public function findAllExtra(int $limit = 0, int $offset = 0, array $options = null) public function updateLastLogin(int $id)
{
$builder = $this->builder();
$data = array();
$data['last_login'] = $this->setDate();
$builder->update($data, array('id' => $id));
}
public function updateLastActivity(int $id)
{
$builder = $this->builder();
$data = array();
$data['last_activity'] = $this->setDate();
$builder->update($data, array('id' => $id));
}
public function isBanned(int $id)
{ {
$builder = $this->builder(); $builder = $this->builder();
@ -53,36 +71,38 @@ class UserModel extends Model
$builder->where($this->deletedField, 0); $builder->where($this->deletedField, 0);
} }
if (isset($options['where'])) $builder->where($this->primaryKey, $id);
{ $builder->where('banned', 1);
foreach ($options['where'] as $key => $value) return $builder->countAllResults();
{ }
$builder->where($key, $value);
} public function existsById(int $id)
} {
$builder = $this->builder();
if (isset($options['order_by'])) if ($this->tempUseSoftDeletes === true)
{ {
foreach ($options['order_by'] as $key => $value) $builder->where($this->deletedField, 0);
{
$builder->orderBy($key, $value);
}
} }
$row = $builder->limit($limit, $offset) $builder->where($this->primaryKey, $id);
->get(); return $builder->countAllResults();
}
$row = $row->getResult($this->tempReturnType);
$row = $this->trigger('afterFind', ['data' => $row, 'limit' => $limit, 'offset' => $offset]); public function existsByEmail(string $email)
{
$builder = $this->builder();
$this->tempReturnType = $this->returnType; if ($this->tempUseSoftDeletes === true)
$this->tempUseSoftDeletes = $this->useSoftDeletes; {
$builder->where($this->deletedField, 0);
}
return $row['data']; $builder->where('email', $email);
return $builder->countAllResults();
} }
public function exists(int $id) public function existsByUsername(string $username)
{ {
$builder = $this->builder(); $builder = $this->builder();
@ -91,8 +111,7 @@ class UserModel extends Model
$builder->where($this->deletedField, 0); $builder->where($this->deletedField, 0);
} }
$builder->like($this->table.'.'.$this->primaryKey, $id); $builder->where('username', $username);
return $builder->countAllResults(); return $builder->countAllResults();
} }

38
Models/UserVariableModel.php

@ -0,0 +1,38 @@
<?php namespace Magefly\Aauth\Models;
use \CodeIgniter\Model;
use Magefly\Aauth\Config\Aauth as AauthConfig;
class UserVariableModel extends Model
{
protected $useSoftDeletes = false;
protected $useTimestamps = true;
protected $createdField = 'created_datetime';
protected $updatedField = 'updated_datetime';
protected $protectFields = false;
public function __construct()
{
parent::__construct();
$this->config = new AauthConfig();
$this->table = $this->config->dbTableUserVariables;
$this->DBGroup = $this->config->dbProfile;
}
public function get($userId, $dataKey, $system = 0)
{
$builder = $this->builder();
$builder->where('user_id', $userId);
$builder->where('data_key', $dataKey);
if ($builder->countAllResults() != 0)
{
return $builder->get()->getFirstRow();
}
else
{
return false;
}
}
}
Loading…
Cancel
Save