Completed
Push — master ( d07a45...da6ba5 )
by
unknown
02:06
created

src/Callbacks/BooleanValidatorCallback.php (1 issue)

Upgrade to new PHP Analysis Engine

These results are based on our legacy PHP analysis, consider migrating to our new PHP analysis engine instead. Learn more

1
<?php
2
3
/**
4
 * TechDivision\Import\Callbacks\BooleanValidatorCallback
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 2019 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-product
18
 * @link      http://www.techdivision.com
19
 */
20
21
namespace TechDivision\Import\Callbacks;
22
23
/**
24
 * A callback implementation that validates the option values of EAV boolean attributes.
25
 *
26
 * @author    Tim Wagner <[email protected]>
27
 * @copyright 2019 TechDivision GmbH <[email protected]>
28
 * @license   http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
29
 * @link      https://github.com/techdivision/import-product
30
 * @link      http://www.techdivision.com
31
 */
32 View Code Duplication
class BooleanValidatorCallback extends ArrayValidatorCallback
33
{
34
35
    /**
36
     * Will be invoked by the observer it has been registered for.
37
     *
38
     * @param string|null $attributeCode  The code of the attribute that has to be validated
39
     * @param string|null $attributeValue The attribute value to be validated
40
     *
41
     * @return mixed The modified value
42
     */
43
    public function handle($attributeCode = null, $attributeValue = null)
44
    {
45
46
        // load the subject instance
47
        $subject = $this->getSubject();
48
49
        // explode the additional attributes
50
        if ($this->isNullable($optionValues = $subject->explode($attributeValue, '='))) {
0 ignored issues
show
$optionValues = $subject...e($attributeValue, '=') is of type array, but the function expects a string.

It seems like the type of the argument is not accepted by the function/method which you are calling.

In some cases, in particular if PHP’s automatic type-juggling kicks in this might be fine. In other cases, however this might be a bug.

We suggest to add an explicit type cast like in the following example:

function acceptsInteger($int) { }

$x = '123'; // string "123"

// Instead of
acceptsInteger($x);

// we recommend to use
acceptsInteger((integer) $x);
Loading history...
51
            return;
52
        }
53
54
        // load the validations
55
        $validations = $this->getValidations($attributeCode);
56
57
        // iterate over the attributes and append them to the row
58
        foreach ($optionValues as $optionValue) {
59
            // query whether or not a boolean value has been specified
60
            if (in_array(strtolower($optionValue), $validations)) {
61
                continue;
62
            }
63
64
            // throw an exception if the value is NOT in the array
65
            throw new \InvalidArgumentException(
66
                sprintf('Found invalid boolean value "%s" for attribute with code "%s"', $optionValue, $attributeCode)
67
            );
68
        }
69
    }
70
}
71