Crypt.php 1.79 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<?php

namespace Drupal\epal;

use Defuse\Crypto\Key;
use Defuse\Crypto\Crypto;
use \Exception;

class Crypt
{

    private $fname; // store

    public function __construct($fname)
    {
        if (is_string($fname)) {
            $this->fname = $fname;
        } else {
Open Source Developer's avatar
crypt    
Open Source Developer committed
19
            $this->fname = __DIR__ . "/../../../../../../app.txt";
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
        }
    }

    /**
     * @throws \Exception If key is not found
     * @return string The key to use
     */
    protected function loadKey()
    {
        if (!is_readable($this->fname) || !is_file($this->fname)) {
            throw new \Exception(__METHOD__ . ':: No file');
        }
        $keystring = file_get_contents($this->fname);
        if ($keystring === false) {
            throw new \Exception(__METHOD__ . ':: Cannot load file');
        }
        return Key::loadFromAsciiSafeString($keystring);
    }

    /**
     * Provided a string value, encrypt and return encrypted value
     *
     * @throws \Defuse\Crypto\Exception\EnvironmentIsBrokenException if encryption cannot be performed
     * @throws \Exception If value to encode is not string
     * @return hex encoded encrypted value
     */
    public function encrypt($data)
    {
        if (!is_string($data)) {
            throw new \Exception("Data to be encoded can only be strings");
        }
        $key = $this->loadKey();
        $dataenc = Crypto::encrypt($data, $key);
        return $dataenc;
    }

    /**
     * Provided a hex encoded encrypted value, decrypt and return original value
     *
     * @throws \Defuse\Crypto\Exception\WrongKeyOrModifiedCiphertextException if decrypt failed!
     * @return string the original value
     */
    public function decrypt($dataenc)
    {
        $key = $this->loadKey();
        $data = Crypto::decrypt($dataenc, $key);
        return $data;
    }
}