Passed
Push — master ( 79c0eb...abf161 )
by Stephen
08:04
created

AbstractModel   A

Complexity

Total Complexity 32

Size/Duplication

Total Lines 274
Duplicated Lines 0 %

Importance

Changes 6
Bugs 2 Features 0
Metric Value
eloc 40
c 6
b 2
f 0
dl 0
loc 274
rs 9.84
wmc 32

23 Methods

Rating   Name   Duplication   Size   Complexity  
A hasAttribute() 0 7 4
A getCreatedForHumansAttribute() 0 3 1
A getIsNewColumn() 0 3 1
A mostRecentChange() 0 10 4
A getLabel() 0 3 1
A newEloquentBuilder() 0 3 1
A wasDeleted() 0 3 2
A getTableName() 0 3 1
A getPrimaryKeyName() 0 3 1
A getUpdatedTimestampAttribute() 0 3 1
A getIdHashAttribute() 0 3 1
A wasUpdated() 0 3 1
A serializeDate() 0 3 1
A wasCreated() 0 3 1
A howNew() 0 3 1
A getCreatedTimestampAttribute() 0 3 1
A isNew() 0 7 2
A query() 0 3 1
A getUpdatedForHumansAttribute() 0 3 1
A hasNullAttribute() 0 3 2
A getDatetimeAttribute() 0 3 1
A getUpdatedDateAttribute() 0 3 1
A getCreatedDateAttribute() 0 3 1
1
<?php
2
3
namespace Sfneal\Models;
4
5
use DateTimeInterface;
6
use Illuminate\Database\Eloquent\Builder;
7
use Illuminate\Database\Eloquent\Model;
8
use Illuminate\Database\Eloquent\SoftDeletes;
9
use Sfneal\Builders\QueryBuilder;
10
use Sfneal\Models\Traits\UploadDirectory;
11
12
abstract class AbstractModel extends Model
13
{
14
    use SoftDeletes,
15
        UploadDirectory;
16
17
    /**
18
     * Retrieve the datetime format used in the timestamp attribute accessors.
19
     *
20
     * @return string
21
     */
22
    protected $timestampFormat = 'm/d/Y h:i a';
23
24
    /**
25
     * Query Builder.
26
     * @param $query
27
     * @return QueryBuilder
28
     */
29
    public function newEloquentBuilder($query)
30
    {
31
        return new QueryBuilder($query);
32
    }
33
34
    /**
35
     * @return QueryBuilder|Builder
36
     */
37
    public static function query()
38
    {
39
        return parent::query();
40
    }
41
42
    /**
43
     * Prepare a date for array / JSON serialization.
44
     *
45
     * @param  DateTimeInterface  $date
46
     * @return string
47
     */
48
    protected function serializeDate(DateTimeInterface $date)
49
    {
50
        return $date->format('Y-m-d H:i:s');
51
    }
52
53
    /**
54
     * Max number of hours ago a model instance could have been created ago and considered 'new'.
55
     */
56
    private const IS_NEW_MAX_HOURS = 168;
57
58
    /**
59
     * Determine if a model instance 'is new' if it was created within the time frame.
60
     *
61
     * @return bool
62
     */
63
    public function isNew(): bool
64
    {
65
        if (empty($this->created_at)) {
66
            return false;
67
        }
68
69
        return strtotime($this->created_at) >= strtotime('-'.self::IS_NEW_MAX_HOURS.' hours');
0 ignored issues
show
Bug introduced by
$this->created_at of type DateTime is incompatible with the type string expected by parameter $datetime of strtotime(). ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

69
        return strtotime(/** @scrutinizer ignore-type */ $this->created_at) >= strtotime('-'.self::IS_NEW_MAX_HOURS.' hours');
Loading history...
70
    }
71
72
    /**
73
     * Determine how new a model instance is by subtracting the current time with the created_at time.
74
     *
75
     * @return false|float
76
     */
77
    public function howNew()
78
    {
79
        return round((time() - strtotime($this->created_at)) / (60 * 60 * 24));
0 ignored issues
show
Bug introduced by
$this->created_at of type DateTime is incompatible with the type string expected by parameter $datetime of strtotime(). ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

79
        return round((time() - strtotime(/** @scrutinizer ignore-type */ $this->created_at)) / (60 * 60 * 24));
Loading history...
80
    }
81
82
    /**
83
     * Return the value of the 'is new' column (default is 'created_at').
84
     *
85
     * @return string
86
     */
87
    public function getIsNewColumn()
88
    {
89
        return $this->getCreatedAtColumn();
90
    }
91
92
    /**
93
     * Determine if a model has an attribute.
94
     *
95
     *  - Optionally determine if the attribute is fillable.
96
     *  - Allows $attr to be null for conditionals where a column may not exist
97
     *
98
     * @param string|null $attr
99
     * @param bool $is_fillable
100
     * @return bool
101
     */
102
    public function hasAttribute(string $attr = null, bool $is_fillable = false): bool
103
    {
104
        // Determine that the attribute exists and optionally weather it is fillable
105
        return
106
            isset($attr) &&
107
            array_key_exists($attr, $this->attributes) &&
108
            ($is_fillable ? array_key_exists($attr, $this->fillable) : true);
109
    }
110
111
    /**
112
     * Determine if a model has attribute that is also null.
113
     *
114
     * @param string $attr
115
     * @return bool
116
     */
117
    public function hasNullAttribute(string $attr): bool
118
    {
119
        return $this->hasAttribute($attr) && is_null($this->getAttribute($attr));
120
    }
121
122
    /**
123
     * Retrieve an integer has of the model instance's ID.
124
     *
125
     * @return int
126
     */
127
    public function getIdHashAttribute()
128
    {
129
        return crc32($this->getKey());
0 ignored issues
show
Bug introduced by
It seems like $this->getKey() can also be of type boolean and null; however, parameter $string of crc32() does only seem to accept string, maybe add an additional type check? ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

129
        return crc32(/** @scrutinizer ignore-type */ $this->getKey());
Loading history...
130
    }
131
132
    /**
133
     * Retrieve the 'created_at' attribute mutated to human readable datetime.
134
     *
135
     * @return string
136
     */
137
    public function getDatetimeAttribute(): string
138
    {
139
        return date('Y-m-d h:i a', strtotime($this->created_at));
0 ignored issues
show
Bug introduced by
$this->created_at of type DateTime is incompatible with the type string expected by parameter $datetime of strtotime(). ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

139
        return date('Y-m-d h:i a', strtotime(/** @scrutinizer ignore-type */ $this->created_at));
Loading history...
140
    }
141
142
    /**
143
     * Returns the default 'label' for a model instance.
144
     *
145
     * @return mixed
146
     */
147
    public function getLabel()
148
    {
149
        return $this->getKey();
150
    }
151
152
    /**
153
     * Retrieve a Model's table name statically.
154
     *
155
     * @return mixed
156
     */
157
    public static function getTableName()
158
    {
159
        return with(new static)->getTable();
160
    }
161
162
    /**
163
     * Retrieve a Model's primary key statically.
164
     *
165
     * @return mixed
166
     */
167
    public static function getPrimaryKeyName()
168
    {
169
        return with(new static)->getKeyName();
170
    }
171
172
    /**
173
     * Determine if a Model was recently 'created'.
174
     *
175
     * @return bool
176
     */
177
    public function wasCreated(): bool
178
    {
179
        return $this->wasRecentlyCreated;
180
    }
181
182
    /**
183
     * Determine if a Model was recently 'updated'.
184
     *
185
     * @return bool
186
     */
187
    public function wasUpdated(): bool
188
    {
189
        return $this->wasChanged();
190
    }
191
192
    /**
193
     * Determine if a Model was recently 'deleted'.
194
     *
195
     * @return bool
196
     */
197
    public function wasDeleted(): bool
198
    {
199
        return ! $this->exists || ! is_null($this->deleted_at);
200
    }
201
202
    /**
203
     * Retrieve the most recent Model change.
204
     *
205
     * @return string
206
     */
207
    public function mostRecentChange(): string
208
    {
209
        if ($this->wasCreated()) {
210
            return 'created';
211
        } elseif ($this->wasUpdated()) {
212
            return 'updated';
213
        } elseif ($this->wasDeleted()) {
214
            return 'deleted';
215
        } else {
216
            return 'unchanged';
217
        }
218
    }
219
220
    /**
221
     * Retrieve the 'updated_at' attribute mutated to timestamp string.
222
     *
223
     *  - 'updated_timestamp' attribute accessor
224
     *
225
     * @return string
226
     */
227
    public function getUpdatedTimestampAttribute(): string
228
    {
229
        return date($this->timestampFormat, strtotime($this->updated_at));
0 ignored issues
show
Bug introduced by
$this->updated_at of type DateTime is incompatible with the type string expected by parameter $datetime of strtotime(). ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

229
        return date($this->timestampFormat, strtotime(/** @scrutinizer ignore-type */ $this->updated_at));
Loading history...
230
    }
231
232
    /**
233
     * Retrieve the 'created_at' attribute mutated to timestamp string.
234
     *
235
     *  - 'created_timestamp' attribute accessor
236
     *
237
     * @return string
238
     */
239
    public function getCreatedTimestampAttribute(): string
240
    {
241
        return date($this->timestampFormat, strtotime($this->created_at));
0 ignored issues
show
Bug introduced by
$this->created_at of type DateTime is incompatible with the type string expected by parameter $datetime of strtotime(). ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

241
        return date($this->timestampFormat, strtotime(/** @scrutinizer ignore-type */ $this->created_at));
Loading history...
242
    }
243
244
    /**
245
     * Retrieve the 'updated_at' attribute mutated to difference for humans string.
246
     *
247
     *  - 'updated_for_humans' attribute accessor
248
     *
249
     * @return string
250
     */
251
    public function getUpdatedForHumansAttribute(): string
252
    {
253
        return $this->updated_at->diffForHumans();
0 ignored issues
show
Bug introduced by
The method diffForHumans() does not exist on DateTime. It seems like you code against a sub-type of DateTime such as Carbon\Carbon. ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-call  annotation

253
        return $this->updated_at->/** @scrutinizer ignore-call */ diffForHumans();
Loading history...
254
    }
255
256
    /**
257
     * Retrieve the 'created_at' attribute mutated to difference for humans string.
258
     *
259
     *  - 'created_for_humans' attribute accessor
260
     *
261
     * @return string
262
     */
263
    public function getCreatedForHumansAttribute(): string
264
    {
265
        return $this->created_at->diffForHumans();
266
    }
267
268
    /**
269
     * Access the 'creation_date' attribute that returns the attribute in 'Y-m-d' format.
270
     *
271
     * @return string
272
     */
273
    public function getCreatedDateAttribute(): string
274
    {
275
        return date('Y-m-d', strtotime($this->created_at));
0 ignored issues
show
Bug introduced by
$this->created_at of type DateTime is incompatible with the type string expected by parameter $datetime of strtotime(). ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

275
        return date('Y-m-d', strtotime(/** @scrutinizer ignore-type */ $this->created_at));
Loading history...
276
    }
277
278
    /**
279
     * Access the 'updated_at' attribute that returns the attribute in 'Y-m-d' format.
280
     *
281
     * @return string
282
     */
283
    public function getUpdatedDateAttribute(): string
284
    {
285
        return date('Y-m-d', strtotime($this->updated_at));
0 ignored issues
show
Bug introduced by
$this->updated_at of type DateTime is incompatible with the type string expected by parameter $datetime of strtotime(). ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

285
        return date('Y-m-d', strtotime(/** @scrutinizer ignore-type */ $this->updated_at));
Loading history...
286
    }
287
}
288