Completed
Push — v3-ssp ( a53c64...2f0a72 )
by Sam
01:27
created

BuildAddonJob::process()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 17
Code Lines 10

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 17
rs 9.4285
c 0
b 0
f 0
cc 2
eloc 10
nc 2
nop 0
1
<?php
2
/**
3
 * A background job which builds a single add-on.
4
 */
5
class BuildAddonJob extends AbstractQueuedJob
6
{
7
    private $packageID;
8
9
    /**
10
     * @var array params
11
     * @throws Exception
12
     */
13
    public function __construct($params = array())
14
    {
15
        if (!empty($params['package'])) {
16
            $this->PackageID = $params['package'];
0 ignored issues
show
Bug introduced by
The property PackageID does not seem to exist. Did you mean packageID?

An attempt at access to an undefined property has been detected. This may either be a typographical error or the property has been renamed but there are still references to its old name.

If you really want to allow access to undefined properties, you can define magic methods to allow access. See the php core documentation on Overloading.

Loading history...
17
        }
18
19
        $this->currentStep = 0;
20
        $this->totalSteps = 1;
21
    }
22
23
    protected function getPackage()
24
    {
25
        return Addon::get()->byID($this->PackageID);
0 ignored issues
show
Bug introduced by
The property PackageID does not seem to exist. Did you mean packageID?

An attempt at access to an undefined property has been detected. This may either be a typographical error or the property has been renamed but there are still references to its old name.

If you really want to allow access to undefined properties, you can define magic methods to allow access. See the php core documentation on Overloading.

Loading history...
26
    }
27
28
    public function process()
29
    {
30
        $package = $this->getPackage();
31
        if (!$package->ID) {
32
            throw new Exception('Package not specified');
33
        }
34
35
        $builder = Injector::inst()->get('AddonBuilder');
36
37
        $builder->build($package);
38
39
        $package->BuildQueued = false;
40
        $package->write();
41
42
        $this->isComplete = true;
43
        $this->currentStep = 1;
44
    }
45
46
    /**
47
     * @return string
48
     */
49
    public function getTitle()
50
    {
51
        return 'Build Addon: ' . $this->getPackge()->Name;
0 ignored issues
show
Bug introduced by
The method getPackge() does not exist on BuildAddonJob. Did you maybe mean getPackage()?

This check marks calls to methods that do not seem to exist on an object.

This is most likely the result of a method being renamed without all references to it being renamed likewise.

Loading history...
52
    }
53
    /**
54
     * Return a signature for this queued job
55
     *
56
     * @return string
57
     */
58
    public function getSignature()
59
    {
60
        return md5(get_class($this) . $this->PackageID);
0 ignored issues
show
Bug introduced by
The property PackageID does not seem to exist. Did you mean packageID?

An attempt at access to an undefined property has been detected. This may either be a typographical error or the property has been renamed but there are still references to its old name.

If you really want to allow access to undefined properties, you can define magic methods to allow access. See the php core documentation on Overloading.

Loading history...
61
    }
62
63
}
64