ConfigPublisher   A
last analyzed

Complexity

Total Complexity 5

Size/Duplication

Total Lines 45
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 2

Test Coverage

Coverage 0%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
wmc 5
c 1
b 0
f 0
lcom 1
cbo 2
dl 0
loc 45
ccs 0
cts 19
cp 0
rs 10

1 Method

Rating   Name   Duplication   Size   Complexity  
B getSource() 0 33 5
1
<?php
2
3
/*
4
 * This file is part of Laravel Service Provider.
5
 *
6
 * (c) DraperStudio <[email protected]>
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11
12
namespace DraperStudio\ServiceProvider\Publisher;
13
14
use InvalidArgumentException;
15
16
class ConfigPublisher extends Publisher
17
{
18
    /**
19
     * Get the source configuration directory to publish.
20
     *
21
     * @param string $packagePath
22
     *
23
     * @return string
24
     *
25
     * @throws \InvalidArgumentException
26
     */
27
    protected function getSource($packagePath)
28
    {
29
        $sources = [
30
            "{$packagePath}/resources/config",
31
            "{$packagePath}/config",
32
        ];
33
34
        // iterate through all possible locations
35
        foreach ($sources as $source) {
36
            if ($this->files->isDirectory($source)) {
37
                $paths = [];
38
39
                // get all files of the current directory
40
                $files = $this->getSourceFiles($source);
41
42
                // iterate through all files
43
                foreach ($files as $file) {
44
                    $destinationPath = $this->getDestinationPath('config', [
45
                        $this->getFileName($file),
46
                    ]);
47
48
                    // if the destination doesn't exist we can add the file to the queue
49
                    if (!$this->files->exists($destinationPath)) {
50
                        $paths[$file] = $destinationPath;
51
                    }
52
                }
53
54
                return $paths;
55
            }
56
        }
57
58
        throw new InvalidArgumentException('Configuration not found.');
59
    }
60
}
61