Completed
Push — master ( 373bb0...78b5b1 )
by Jasper
15:51 queued 14:04
created

EncryptedAdapter::writeStream()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 1
c 1
b 0
f 0
nc 1
nop 3
dl 0
loc 3
ccs 2
cts 2
cp 1
crap 1
rs 10
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Swis\Flysystem\Encrypted;
6
7
use Illuminate\Contracts\Encryption\Encrypter;
8
use Illuminate\Support\Traits\ForwardsCalls;
9
use League\Flysystem\AdapterInterface;
10
use League\Flysystem\Config;
11
use League\Flysystem\Util\MimeType;
12
13
class EncryptedAdapter implements AdapterInterface
14
{
15 1
    use ForwardsCalls;
16
17
    /**
18
     * @var \League\Flysystem\AdapterInterface
19
     */
20
    private $adapter;
21
22
    /**
23
     * @var \Illuminate\Contracts\Encryption\Encrypter
24
     */
25
    private $encrypter;
26
27
    /**
28
     * @param \League\Flysystem\AdapterInterface $adapter
29
     * @param \Illuminate\Contracts\Encryption\Encrypter $encrypter
30
     */
31 222
    public function __construct(AdapterInterface $adapter, Encrypter $encrypter)
32
    {
33 222
        $this->adapter = $adapter;
34 222
        $this->encrypter = $encrypter;
35 222
    }
36
37
    /**
38
     * @inheritDoc
39
     */
40 60
    public function write($path, $contents, Config $config)
41
    {
42 60
        return $this->adapter->write($path, $this->encrypter->encrypt($contents), $config);
43
    }
44
45
    /**
46
     * @inheritDoc
47
     */
48 30
    public function writeStream($path, $resource, Config $config)
49
    {
50 30
        return $this->write($path, stream_get_contents($resource), $config);
51
    }
52
53
    /**
54
     * @inheritDoc
55
     */
56 60
    public function update($path, $contents, Config $config)
57
    {
58 60
        return $this->adapter->update($path, $this->encrypter->encrypt($contents), $config);
59
    }
60
61
    /**
62
     * @inheritDoc
63
     */
64 30
    public function updateStream($path, $resource, Config $config)
65
    {
66 30
        return $this->update($path, stream_get_contents($resource), $config);
67
    }
68
69
    /**
70
     * @inheritDoc
71
     */
72
    public function rename($path, $newpath)
73
    {
74
        return $this->adapter->rename($path, $newpath);
75
    }
76
77
    /**
78
     * @inheritDoc
79
     */
80
    public function copy($path, $newpath)
81
    {
82
        return $this->adapter->copy($path, $newpath);
83
    }
84
85
    /**
86
     * @inheritDoc
87
     */
88
    public function delete($path)
89
    {
90
        return $this->adapter->delete($path);
91
    }
92
93
    /**
94
     * @inheritDoc
95
     */
96
    public function deleteDir($dirname)
97
    {
98
        return $this->adapter->deleteDir($dirname);
99
    }
100
101
    /**
102
     * @inheritDoc
103
     */
104
    public function createDir($dirname, Config $config)
105
    {
106
        return $this->adapter->createDir($dirname, $config);
107
    }
108
109
    /**
110
     * @inheritDoc
111
     */
112
    public function setVisibility($path, $visibility)
113
    {
114
        return $this->adapter->setVisibility($path, $visibility);
115
    }
116
117
    /**
118
     * @inheritDoc
119
     */
120
    public function has($path)
121
    {
122
        return $this->adapter->has($path);
123
    }
124
125
    /**
126
     * @inheritDoc
127
     */
128 90
    public function read($path)
129
    {
130 90
        $result = $this->adapter->read($path);
131
132 90
        if ($result === false) {
133
            return false;
134
        }
135
136 90
        return array_merge($result, ['contents' => $this->encrypter->decrypt($result['contents'])]);
137
    }
138
139
    /**
140
     * @inheritDoc
141
     */
142 30
    public function readStream($path)
143
    {
144 30
        $result = $this->read($path);
145
146 30
        if ($result === false) {
147
            return false;
148
        }
149
150 30
        $stream = tmpfile();
151
152 30
        if ($stream === false) {
153
            return false;
154
        }
155
156 30
        fwrite($stream, $result['contents']);
157 30
        fseek($stream, 0);
158 30
        unset($result['contents']);
159
160 30
        return array_merge($result, compact('stream'));
161
    }
162
163
    /**
164
     * @inheritDoc
165
     */
166
    public function listContents($directory = '', $recursive = false)
167
    {
168
        return $this->adapter->listContents($directory, $recursive);
169
    }
170
171
    /**
172
     * @inheritDoc
173
     */
174
    public function getMetadata($path)
175
    {
176
        return $this->adapter->getMetadata($path);
177
    }
178
179
    /**
180
     * @inheritDoc
181
     */
182 30
    public function getSize($path)
183
    {
184 30
        $result = $this->adapter->getSize($path);
185 30
        $contents = $this->read($path);
186
187 30
        if ($result === false || $contents === false) {
188
            return false;
189
        }
190
191 30
        $result['size'] = \strlen($contents['contents']);
192
193 30
        return $result;
194
    }
195
196
    /**
197
     * @inheritDoc
198
     */
199 12
    public function getMimetype($path)
200
    {
201 12
        $result = $this->adapter->getMimetype($path);
202
203 12
        if ($result === false) {
204
            return false;
205
        }
206
207 12
        $result['mimetype'] = MimeType::detectByFilename($path);
208
209 12
        return $result;
210
    }
211
212
    /**
213
     * @inheritDoc
214
     */
215
    public function getTimestamp($path)
216
    {
217
        return $this->adapter->getTimestamp($path);
218
    }
219
220
    /**
221
     * @inheritDoc
222
     */
223
    public function getVisibility($path)
224
    {
225
        return $this->adapter->getVisibility($path);
226
    }
227
228
    /**
229
     * Dynamically pass missing methods to the decorated adapter.
230
     *
231
     * @param string $method
232
     * @param array $parameters
233
     *
234
     * @return mixed
235
     */
236 120
    public function __call($method, $parameters)
237
    {
238 120
        return $this->forwardCallTo($this->adapter, $method, $parameters);
239
    }
240
}
241