RequireValidEncryptionIV::__construct()   A
last analyzed

Complexity

Conditions 2
Paths 2

Size

Total Lines 10
Code Lines 4

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 10
rs 9.4285
c 0
b 0
f 0
cc 2
eloc 4
nc 2
nop 1
1
<?php
2
3
declare(strict_types=1);
4
5
/**
6
 * Copyright (c) 2017-present Ganbaro Digital Ltd
7
 * All rights reserved.
8
 *
9
 * Redistribution and use in source and binary forms, with or without
10
 * modification, are permitted provided that the following conditions
11
 * are met:
12
 *
13
 *   * Redistributions of source code must retain the above copyright
14
 *     notice, this list of conditions and the following disclaimer.
15
 *
16
 *   * Redistributions in binary form must reproduce the above copyright
17
 *     notice, this list of conditions and the following disclaimer in
18
 *     the documentation and/or other materials provided with the
19
 *     distribution.
20
 *
21
 *   * Neither the names of the copyright holders nor the names of his
22
 *     contributors may be used to endorse or promote products derived
23
 *     from this software without specific prior written permission.
24
 *
25
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
26
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
27
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
28
 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
29
 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
30
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
31
 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
32
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
33
 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
34
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
35
 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
36
 * POSSIBILITY OF SUCH DAMAGE.
37
 *
38
 * @category  Libraries
39
 * @package   MessagingPipeline/Requirements
40
 * @author    Stuart Herbert <[email protected]>
41
 * @copyright 2017-present Ganbaro Digital Ltd www.ganbarodigital.com
42
 * @license   http://www.opensource.org/licenses/bsd-license.php  BSD License
43
 * @link      http://ganbarodigital.github.io/php-mv-messaging-pipeline
44
 */
45
46
namespace GanbaroDigital\MessagingPipeline\V1\Requirements;
47
48
use GanbaroDigital\Defensive\V1\Interfaces\ListRequirement;
49
use GanbaroDigital\Defensive\V1\Interfaces\Requirement;
50
use GanbaroDigital\Defensive\V1\Requirements\InvokeableRequirement;
51
use GanbaroDigital\Defensive\V1\Requirements\ListableRequirement;
52
use GanbaroDigital\MessagingPipeline\V1\Checks\IsValidEncryptionCipher;
53
use GanbaroDigital\MessagingPipeline\V1\Checks\IsValidEncryptionIV;
54
use GanbaroDigital\MessagingPipeline\V1\Exceptions\InvalidEncryptionIV;
55
use GanbaroDigital\MessagingPipeline\V1\Exceptions\UnsupportedEncryptionCipher;
56
57
/**
58
 * make sure that we have a valid encryption initialisation vector
59
 */
60
class RequireValidEncryptionIV implements Requirement, ListRequirement
61
{
62
    // saves us having to declare ::__invoke() ourselves
63
    use InvokeableRequirement;
64
65
    // saves us having to declare ::toList() ourselves
66
    use ListableRequirement;
67
68
    /**
69
     * the encryption cipher that we're checking against
70
     * @var string
71
     */
72
    private $encryptionCipher;
73
74
    /**
75
     * create a Requirement that is ready to use
76
     *
77
     * @param string $encryptionCipher
78
     *        the encryption cipher that we're checking against
79
     */
80
    public function __construct(string $encryptionCipher)
81
    {
82
        // robustness!!
83
        if (!IsValidEncryptionCipher::check($encryptionCipher)) {
84
            throw UnsupportedEncryptionCipher::newFromInputParameter($encryptionCipher, '$encryptionCipher');
85
        }
86
87
        // all is well
88
        $this->encryptionCipher = $encryptionCipher;
89
    }
90
91
    /**
92
     * create a Requirement that is ready to use
93
     *
94
     * @param string $encryptionCipher
95
     *        the encryption cipher that we're checking against
96
     * @return Requirement
97
     */
98
    public static function apply(string $encryptionCipher) : Requirement
99
    {
100
        return new static($encryptionCipher);
101
    }
102
103
    /**
104
     * make sure that we have a valid encryption cipher
105
     *
106
     * @param  string $item
107
     *         the item to examine
108
     * @param  string $fieldOrVarName
109
     *         what do you call $item in your own code?
110
     * @return void
111
     *
112
     * @throws UnsupportedEncryptionIV
113
     *         if $item isn't a valid initialisation vector for the given
114
     *         encryption type
115
     */
116
    public function to($item, $fieldOrVarName='$item')
117
    {
118
        // are we happy?
119
        if (IsValidEncryptionIV::check($this->encryptionCipher, $item)) {
120
            // yes we are
121
            return;
122
        }
123
124
        // if we get here, then no, we are not happy
125
        throw InvalidEncryptionIV::newFromInputParameter($item, $fieldOrVarName, [
126
            'cipher' => $this->encryptionCipher
127
        ]);
128
    }
129
}