1 | <?php |
||
31 | trait BlameableQueryTrait |
||
32 | { |
||
33 | use QueryTrait; |
||
34 | |||
35 | /** |
||
36 | * Specify confirmation. |
||
37 | * @param boolean $isConfirmed |
||
38 | * @return $this |
||
39 | */ |
||
40 | 4 | public function confirmed($isConfirmed = true) |
|
41 | { |
||
42 | 4 | $model = $this->noInitModel; |
|
|
|||
43 | 4 | if (!is_string($model->confirmationAttribute)) { |
|
44 | 3 | return $this; |
|
45 | } |
||
46 | 1 | return $this->andWhere([$model->confirmationAttribute => $isConfirmed]); |
|
47 | } |
||
48 | |||
49 | /** |
||
50 | * Specify content. |
||
51 | * @param mixed $content |
||
52 | * @param false|string $like false, 'like', 'or like', 'not like', 'or not like'. |
||
53 | * @return $this |
||
54 | */ |
||
55 | 4 | public function content($content, $like = false) |
|
60 | |||
61 | /** |
||
62 | * Specify parent. |
||
63 | * @param array|string $guid parent guid or array of them. non-parent if |
||
64 | * empty. If you don't want to specify parent, please do not access this |
||
65 | * method. |
||
66 | * @return $this |
||
67 | */ |
||
68 | 2 | public function parentGuid($guid) |
|
69 | { |
||
70 | 2 | $model = $this->noInitModel; |
|
71 | 2 | if (!is_string($model->parentAttribute)) { |
|
72 | 1 | return $this; |
|
73 | } |
||
74 | 1 | if ($guid instanceof $model) { |
|
75 | 1 | $guid = $guid->getGUID(); |
|
76 | } |
||
77 | 1 | return $this->andWhere([$model->parentAttribute => $guid]); |
|
78 | } |
||
79 | |||
80 | /** |
||
81 | * Specify creator(s). |
||
82 | * @param string|array $guid |
||
83 | * @return $this |
||
84 | */ |
||
85 | 24 | public function createdBy($guid) |
|
86 | { |
||
87 | 24 | $model = $this->noInitModel; |
|
88 | 24 | if (!is_string($model->createdByAttribute) || empty($model->createdByAttribute)) { |
|
89 | return $this; |
||
90 | } |
||
91 | 24 | if ($guid instanceof BaseUserModel) { |
|
92 | 14 | $guid = $guid->getGUID(); |
|
93 | } |
||
94 | 24 | return $this->andWhere([$model->createdByAttribute => $guid]); |
|
95 | } |
||
96 | |||
97 | /** |
||
98 | * Specify last updater(s). |
||
99 | * @param string|array $guid |
||
100 | * @return $this |
||
101 | */ |
||
102 | 2 | public function updatedBy($guid) |
|
113 | |||
114 | /** |
||
115 | * Attach current identity to createdBy condition. |
||
116 | * @param BaseUserModel $identity |
||
117 | * @return $this |
||
118 | */ |
||
119 | 10 | public function byIdentity($identity = null) |
|
129 | } |
||
130 |
In PHP it is possible to write to properties without declaring them. For example, the following is perfectly valid PHP code:
Generally, it is a good practice to explictly declare properties to avoid accidental typos and provide IDE auto-completion: