1
|
|
|
<?php namespace Maqe\Qwatcher\Tracks; |
2
|
|
|
|
3
|
|
|
use Illuminate\Queue\Queue; |
4
|
|
|
use Carbon\Carbon; |
5
|
|
|
use Maqe\Qwatcher\Tracks\Enums\StatusType; |
6
|
|
|
|
7
|
|
|
abstract class TracksAbstract extends Queue |
8
|
|
|
{ |
9
|
|
|
/** |
10
|
|
|
* Push job to tracks table |
11
|
|
|
* |
12
|
|
|
* @param $id The queue id |
13
|
|
|
* @param $job The queue job object |
14
|
|
|
* @param array $meta The meta data array |
15
|
|
|
* @return mixed |
16
|
|
|
*/ |
17
|
|
|
abstract public function pushToTracks($id, $job = null, array $meta = []); |
18
|
|
|
|
19
|
|
|
/** |
20
|
|
|
* Create tracks record from job |
21
|
|
|
* |
22
|
|
|
* @param mixed $job The queue job object |
23
|
|
|
* @param array $meta The meta data array |
24
|
|
|
* @return integer $id The new tracks id |
25
|
|
|
*/ |
26
|
|
|
protected function create($id, $job = null, array $meta = []) |
27
|
|
|
{ |
28
|
|
|
return Tracks::create($this->prepareRecord($id, $job, $meta))->id; |
|
|
|
|
29
|
|
|
} |
30
|
|
|
|
31
|
|
|
/** |
32
|
|
|
* Update status tracks record by queue id and status type |
33
|
|
|
* |
34
|
|
|
* @param integer $id The queue id to track queue record |
35
|
|
|
* @param enum $status The status tracks type |
36
|
|
|
* @return boolean|mixed The update result |
37
|
|
|
*/ |
38
|
|
|
protected function update($id, $job, $status) |
39
|
|
|
{ |
40
|
|
|
return Tracks::where('queue_id', $id)->update(['attempts' => $job->attempts(), "{$status}_at" => Carbon::now()]); |
41
|
|
|
} |
42
|
|
|
|
43
|
|
|
/** |
44
|
|
|
* Prepare record before create new record |
45
|
|
|
* |
46
|
|
|
* @param mixed $job The queue job object |
47
|
|
|
* @return array The array for input to database |
48
|
|
|
*/ |
49
|
|
|
protected function prepareRecord($id, $job, array $meta = []) |
50
|
|
|
{ |
51
|
|
|
return [ |
52
|
|
|
'driver' => config('queue.default'), |
53
|
|
|
'queue_id' => $id, |
54
|
|
|
'payload' => $this->createPayload($job), |
55
|
|
|
'attempts' => 0, |
56
|
|
|
'job_name' => get_class($job), |
57
|
|
|
'meta' => json_encode($this->setMetaData($job, $meta)), |
58
|
|
|
'queue_at' => Carbon::now(), |
59
|
|
|
]; |
60
|
|
|
} |
61
|
|
|
|
62
|
|
|
/** |
63
|
|
|
* Include default meta data job_name into meta column |
64
|
|
|
* |
65
|
|
|
* @param $job The queue job object |
66
|
|
|
* @param array $meta The meta array after add default |
67
|
|
|
*/ |
68
|
|
|
protected function setMetaData($job, array $meta = []) |
69
|
|
|
{ |
70
|
|
|
return array_add($meta, 'job_name', get_class($job)); |
71
|
|
|
} |
72
|
|
|
} |
73
|
|
|
|
Since your code implements the magic getter
_get
, this function will be called for any read access on an undefined variable. You can add the@property
annotation to your class or interface to document the existence of this variable.If the property has read access only, you can use the @property-read annotation instead.
Of course, you may also just have mistyped another name, in which case you should fix the error.
See also the PhpDoc documentation for @property.