Completed
Pull Request — develop (#225)
by
unknown
09:12 queued 07:20
created

IdentityFilesystemWriter   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 29
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 1

Importance

Changes 0
Metric Value
wmc 3
lcom 1
cbo 1
dl 0
loc 29
c 0
b 0
f 0
rs 10

3 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 4 1
A write() 0 5 1
A createFileName() 0 5 1
1
<?php
2
3
/**
4
 * Copyright 2020 SURFnet B.V.
5
 *
6
 * Licensed under the Apache License, Version 2.0 (the "License");
7
 * you may not use this file except in compliance with the License.
8
 * You may obtain a copy of the License at
9
 *
10
 *     http://www.apache.org/licenses/LICENSE-2.0
11
 *
12
 * Unless required by applicable law or agreed to in writing, software
13
 * distributed under the License is distributed on an "AS IS" BASIS,
14
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
 * See the License for the specific language governing permissions and
16
 * limitations under the License.
17
 */
18
19
namespace Surfnet\StepupSelfService\SelfServiceBundle\Service\RemoteVetting\Encryption;
20
21
use Surfnet\StepupSelfService\SelfServiceBundle\Service\RemoteVetting\Configuration\RemoteVettingConfiguration;
22
23
class IdentityFilesystemWriter implements IdentityWriterInterface
24
{
25
    /**
26
     * @var RemoteVettingConfiguration
27
     */
28
    private $configuration;
29
30
    public function __construct(RemoteVettingConfiguration $configuration)
31
    {
32
        $this->configuration = $configuration;
33
    }
34
35
    /**
36
     * Writes identity data to a data store. The data should be passed as a string.
37
     *
38
     * @param string $data
39
     */
40
    public function write($data)
41
    {
42
        $fileName = $this->createFileName($this->configuration->getLocation());
43
        file_put_contents($fileName, $data."\n");
44
    }
45
46
    private function createFileName($location)
0 ignored issues
show
Documentation introduced by
The return type could not be reliably inferred; please add a @return annotation.

Our type inference engine in quite powerful, but sometimes the code does not provide enough clues to go by. In these cases we request you to add a @return annotation as described here.

Loading history...
47
    {
48
        $fileName = uniqid('identity_', true);
49
        return "{$location}/{$fileName}";
50
    }
51
}
52