Completed
Pull Request — master (#38)
by Tim
10:16
created

UrlRewriteAction::update()   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 4
cp 0
rs 10
c 0
b 0
f 0
cc 1
eloc 2
nc 1
nop 2
crap 2
1
<?php
2
3
/**
4
 * TechDivision\Import\Actions\UrlRewriteAction
5
 *
6
 * NOTICE OF LICENSE
7
 *
8
 * This source file is subject to the Open Software License (OSL 3.0)
9
 * that is available through the world-wide-web at this URL:
10
 * http://opensource.org/licenses/osl-3.0.php
11
 *
12
 * PHP version 5
13
 *
14
 * @author    Tim Wagner <[email protected]>
15
 * @copyright 2016 TechDivision GmbH <[email protected]>
16
 * @license   http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
17
 * @link      https://github.com/techdivision/import-category
18
 * @link      http://www.techdivision.com
19
 */
20
21
namespace TechDivision\Import\Actions;
22
23
use TechDivision\Import\Utils\EntityStatus;
24
25
/**
26
 * An action implementation that provides CRUD functionality for URL rewrites.
27
 *
28
 * @author    Tim Wagner <[email protected]>
29
 * @copyright 2016 TechDivision GmbH <[email protected]>
30
 * @license   http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
31
 * @link      https://github.com/techdivision/import-category
32
 * @link      http://www.techdivision.com
33
 */
34
class UrlRewriteAction extends AbstractAction
35
{
36
37
    /**
38
     * Helper method that create/update the passed entity, depending on
39
     * the entity's status.
40
     *
41
     * @param array $row The entity data to create/update
42
     *
43
     * @return string The last inserted ID
44
     */
45
    public function persist(array $row)
46
    {
47
48
        // load the method name
49
        $methodName = $row[EntityStatus::MEMBER_NAME];
50
51
        // invoke the method
52
        return $this->$methodName($row);
53
    }
54
55
    /**
56
     * Creates's the entity with the passed attributes.
57
     *
58
     * @param array       $row  The attributes of the entity to create
59
     * @param string|null $name The name of the prepared statement that has to be executed
60
     *
61
     * @return string The last inserted ID
62
     */
63
    public function create($row, $name = null)
64
    {
65
        return $this->getCreateProcessor()->execute($row, $name);
66
    }
67
68
    /**
69
     * Update's the entity with the passed attributes.
70
     *
71
     * @param array       $row  The attributes of the entity to update
72
     * @param string|null $name The name of the prepared statement that has to be executed
73
     *
74
     * @return string The ID of the updated product
75
     */
76
    public function update($row, $name = null)
77
    {
78
        return $this->getUpdateProcessor()->execute($row, $name);
79
    }
80
}
81