-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathModel.php
116 lines (97 loc) · 3.9 KB
/
Model.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
<?php
namespace jeannick\phpmvc;
abstract class Model
{
public const RULE_REQUIRED = 'required';
public const RULE_EMAIL = 'email';
public const RULE_MIN = 'min';
public const RULE_MAX = 'max';
public const RULE_MATCH = 'match';
public const RULE_UNIQUE = 'unique';
public function loadData($data){
foreach ($data as $key => $value){
if(property_exists($this,$key)){
$this->{$key} = $value;
}
}
}
abstract public function rules(): array;
public function labels(): array
{
return [];
}
public function getLabel($attribute){
return $this->labels()[$attribute] ?? $attribute;
}
// public array $errors = [];
public $errors = [];
public function validate(){
foreach ($this->rules() as $attribute => $rules){
$value = $this->{$attribute};
foreach ($rules as $rule){
$ruleName = $rule;
if(!is_string($ruleName)){
$ruleName = $rule[0];
}
if($ruleName === self::RULE_REQUIRED && !$value){
$this->addErrorForRule($attribute, self::RULE_REQUIRED);
}
if ($ruleName === self::RULE_EMAIL && !filter_var($value,FILTER_VALIDATE_EMAIL)){
$this->addErrorForRule($attribute, self::RULE_EMAIL);
}
if (($ruleName === self::RULE_MIN) && (strlen('min') == $rule['min'])){
$this->addErrorForRule($attribute, self::RULE_MIN,$rule);
}
if (($ruleName === self::RULE_MAX) && (strlen('max') == $rule['max'])){
$this->addErrorForRule($attribute, self::RULE_MAX,$rule);
}
if ($ruleName === self::RULE_MATCH && $value !== $this->{$rule['match']}){
$rule['match'] = $this->getLabel($rule['match']);
$this->addErrorForRule($attribute, self::RULE_MATCH,$rule);
}
if ($ruleName === self::RULE_UNIQUE){
$className = $rule['class'];
$uniqueAttr = $rule['attribute'] ?? $attribute;
$tableName = $className::tableName();
$statement = Application::$app->db->prepare("SELECT * FROM $tableName WHERE $uniqueAttr =:attr");
$statement->bindValue(":attr", $value);
$statement->execute();
$record = $statement->fetchObject();
if($record){
$this->addErrorForRule($attribute, self::RULE_UNIQUE, ['field'=>$this->getLabel($attribute)]);
}
}
}
}
return empty($this->errors);
}
private function addErrorForRule(string $attribute, string $rule, $params = [])
{
$message = $this->errorMessages()[$rule] ?? '';
foreach ($params as $key => $value){
$message = str_replace("{{$key}}",$value,$message);
}
$this->errors[$attribute][] = $message;
}
public function addError(string $attribute, string $message)
{
$this->errors[$attribute][] = $message;
}
public function errorMessages()
{
return[
self::RULE_REQUIRED => 'This field is required',
self::RULE_EMAIL => 'This field must be a valid email address',
self::RULE_MAX => 'Max length of this field must be {max}',
self::RULE_MIN => 'Min length of this field must be {min}',
self::RULE_MATCH => 'This field must be the same as {match}',
self::RULE_UNIQUE => 'Record with this {field} already exists',
];
}
public function hasError($attribute){
return $this->errors[$attribute] ?? false;
}
public function getFirstError($attribute){
return $this->errors[$attribute][0] ?? false;
}
}