Completed
Push — master ( 11c89b...a1f77e )
by Matthew
03:37
created

JobManager::setTube()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 0
Metric Value
dl 0
loc 4
ccs 0
cts 3
cp 0
rs 10
c 0
b 0
f 0
cc 1
eloc 2
nc 1
nop 1
crap 2
1
<?php
2
3
namespace Dtc\QueueBundle\Beanstalkd;
4
5
use Dtc\QueueBundle\Model\AbstractJobManager;
6
use Dtc\QueueBundle\Model\Job as BaseJob;
7
use Pheanstalk\Pheanstalk;
8
9
class JobManager extends AbstractJobManager
10
{
11
    const DEFAULT_RESERVE_TIMEOUT = 5; // seconds
12
13
    /** @var Pheanstalk */
14
    protected $beanstalkd;
15
16
    protected $tube;
17
18
    protected $reserveTimeout = self::DEFAULT_RESERVE_TIMEOUT;
19
20
    public function setBeanstalkd(Pheanstalk $beanstalkd)
21
    {
22
        $this->beanstalkd = $beanstalkd;
23
    }
24
25
    public function setTube($tube)
26
    {
27
        $this->tube = $tube;
28
    }
29
30
    public function setReserveTimeout($timeout)
31
    {
32
        $this->reserveTimeout = $timeout;
33
    }
34
35 2
    public function save(\Dtc\QueueBundle\Model\Job $job)
36
    {
37
        /** @var Job $job */
38 2
        $message = $job->toMessage();
39 2
        $arguments = [$message, $job->getPriority(), $job->getDelay(), $job->getTtr()];
40 2
        $method = 'put';
41 2
        if ($this->tube) {
42
            array_unshift($arguments, $this->tube);
43
            $method .= 'InTube';
44
        }
45 2
        $jobId = call_user_func_array([$this->beanstalkd, $method], $arguments);
46 2
        $job->setId($jobId);
47
48
        // Ideally we should get this from beanstalk, but to save the roundtrip time, we do this here
49 2
        $job->setBeanJob($this->getBeanJob($jobId, $message));
50
51 2
        return $job;
52
    }
53
54 2
    public function getBeanJob($jobId, $data)
55
    {
56 2
        return new \Pheanstalk\Job($jobId, $data);
57
    }
58
59
    /**
60
     * @param string|null     $workerName
61
     * @param string|null     $methodName
62
     * @param bool            $prioritize
63
     * @param int|string|null $runId
64
     *
65
     * @return Job|null
66
     *
67
     * @throws \Exception
68
     */
69 2
    public function getJob($workerName = null, $methodName = null, $prioritize = true, $runId = null)
70
    {
71 2
        if (null !== $methodName) {
72
            throw new \Exception('Unsupported');
73
        }
74 2
        if (null !== $workerName) {
75 1
            throw new \Exception('Unsupported');
76
        }
77
78 1
        $beanstalkd = $this->beanstalkd;
79 1
        if ($this->tube) {
80
            $beanstalkd = $this->beanstalkd->watch($this->tube);
81
        }
82
83
        do {
84 1
            $expiredJob = false;
85 1
            $job = $this->findJob($beanstalkd, $expiredJob, $runId);
86 1
        } while ($expiredJob);
87
88 1
        return $job;
89
    }
90
91
    /**
92
     * @param Pheanstalk      $beanstalkd
93
     * @param bool            $expiredJob
94
     * @param int|string|null $runId
95
     *
96
     * @return Job|null
97
     */
98 1
    protected function findJob(Pheanstalk $beanstalkd, &$expiredJob, $runId)
99
    {
100 1
        $beanJob = $beanstalkd->reserve($this->reserveTimeout);
101 1
        if ($beanJob) {
102 1
            $job = new Job();
103 1
            $job->fromMessage($beanJob->getData());
104 1
            $job->setId($beanJob->getId());
105 1
            $job->setRunId($runId);
106
107 1
            if (($expiresAt = $job->getExpiresAt()) && $expiresAt->getTimestamp() < time()) {
108
                $expiredJob = true;
109
                $beanstalkd->delete($beanJob);
110
111
                return null;
112
            }
113 1
            $job->setBeanJob($beanJob);
114
115 1
            return $job;
116
        }
117
118
        return null;
119
    }
120
121 1
    public function deleteJob(\Dtc\QueueBundle\Model\Job $job)
122
    {
123 1
        $this->beanstalkd
124 1
            ->delete($job);
125 1
    }
126
127
    // Save History get called upon completion of the job
128
    public function saveHistory(\Dtc\QueueBundle\Model\Job $job)
129
    {
130
        if (BaseJob::STATUS_SUCCESS === $job->getStatus()) {
131
            $this->beanstalkd
132
                ->delete($job);
133
        }
134
    }
135
136
    public function getStats()
137
    {
138
        return $this->beanstalkd->stats();
139
    }
140
}
141