DecryptString::from()   B
last analyzed

Complexity

Conditions 3
Paths 2

Size

Total Lines 29
Code Lines 16

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 29
rs 8.8571
c 0
b 0
f 0
cc 3
eloc 16
nc 2
nop 5
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/Operations
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\Operations;
47
48
use GanbaroDigital\MessagingPipeline\V1\Exceptions\CannotDecryptString;
49
use GanbaroDigital\MessagingPipeline\V1\Requirements\RequireValidEncryptionCipher;
50
use GanbaroDigital\MessagingPipeline\V1\Requirements\RequireValidEncryptionIV;
51
52
/**
53
 * decrypt a previously encrypted string
54
 */
55
class DecryptString
56
{
57
    /**
58
     * decrypt a previously encrypted string
59
     *
60
     * @param  string $item
61
     *         the string that you want to decrypt
62
     * @param  string $fieldOrVarName
63
     *         what do you call $item in your own code?
64
     * @param  string $encryptionType
65
     *         what kind of encryption cipher do you want to use?
66
     *         this must be supported by OpenSSL
67
     * @param  string $encryptionKey
68
     *         a password given to you by the person who encrypted the string
69
     * @param  string $iv
70
     *         the initialisation vector to used to decrypt the string
71
     * @return string
72
     *         the decrypted copy of $item
73
     */
74
    public static function from(string $item, string $fieldOrVarName, string $encryptionType, string $encryptionKey, string $iv)
75
    {
76
        // robustness!
77
        RequireValidEncryptionCipher::apply()->to($encryptionType, '$encryptionType');
78
        RequireValidEncryptionIV::apply($encryptionType)->to($iv, '$iv');
79
80
        // deal with decryption problems
81
        $errorMessage = null;
82
        set_error_handler(function ($errno, $errstr) use (&$errorMessage) {
83
            $errorMessage = $errstr;
84
        });
85
        $retval = openssl_decrypt(
86
            $item,
87
            $encryptionType,
88
            $encryptionKey,
89
            OPENSSL_RAW_DATA,
90
            $iv
91
        );
92
        restore_error_handler();
93
94
        // did we manage to decrypt it?
95
        if ($errorMessage || !$retval) {
96
            // something went wrong
97
            throw CannotDecryptString::newFromInputParameter($item, $fieldOrVarName, ['PHP_error' => $errorMessage]);
98
        }
99
100
        // if we get here, then all is well
101
        return $retval;
102
    }
103
}