RequireValidEncryptionCipher   A
last analyzed

Complexity

Total Complexity 3

Size/Duplication

Total Lines 42
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 4

Importance

Changes 0
Metric Value
wmc 3
lcom 0
cbo 4
dl 0
loc 42
rs 10
c 0
b 0
f 0

2 Methods

Rating   Name   Duplication   Size   Complexity  
A apply() 0 4 1
A to() 0 11 2
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\Exceptions\UnsupportedEncryptionCipher;
54
55
/**
56
 * make sure that we have a valid encryption cipher name
57
 */
58
class RequireValidEncryptionCipher implements Requirement, ListRequirement
59
{
60
    // saves us having to declare ::__invoke() ourselves
61
    use InvokeableRequirement;
62
63
    // saves us having to declare ::toList() ourselves
64
    use ListableRequirement;
65
66
    /**
67
     * create a Requirement that is ready to use
68
     *
69
     * @return Requirement
70
     */
71
    public static function apply() : Requirement
72
    {
73
        return new static();
74
    }
75
76
    /**
77
     * make sure that we have a valid encryption cipher
78
     *
79
     * @param  string $item
80
     *         the item to examine
81
     * @param  string $fieldOrVarName
82
     *         what do you call $item in your own code?
83
     * @return void
84
     *
85
     * @throws UnsupportedEncryptionCipher
86
     *         if we have something that isn't a MessagingPipelineInstruction
87
     */
88
    public function to($item, $fieldOrVarName='$item')
89
    {
90
        // are we happy?
91
        if (IsValidEncryptionCipher::check($item)) {
92
            // yes we are
93
            return;
94
        }
95
96
        // if we get here, then no, we are not happy
97
        throw UnsupportedEncryptionCipher::newFromInputParameter($item, $fieldOrVarName);
98
    }
99
}