1 | <?php |
||||
2 | |||||
3 | namespace Xima\DepmonBundle\Command; |
||||
4 | |||||
5 | |||||
6 | use Psr\Log\LoggerInterface; |
||||
7 | use Symfony\Bundle\FrameworkBundle\Command\ContainerAwareCommand; |
||||
8 | use Symfony\Component\Console\Style\SymfonyStyle; |
||||
0 ignored issues
–
show
|
|||||
9 | use Xima\DepmonBundle\Service\Aggregator; |
||||
10 | use Xima\DepmonBundle\Service\Cache; |
||||
11 | use Psr\Cache\InvalidArgumentException; |
||||
12 | use Symfony\Component\Console\Helper\ProgressBar; |
||||
0 ignored issues
–
show
The type
Symfony\Component\Console\Helper\ProgressBar was not found. Maybe you did not declare it correctly or list all dependencies?
The issue could also be caused by a filter entry in the build configuration.
If the path has been excluded in your configuration, e.g. filter:
dependency_paths: ["lib/*"]
For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths ![]() |
|||||
13 | use Symfony\Component\Console\Input\InputInterface; |
||||
0 ignored issues
–
show
The type
Symfony\Component\Console\Input\InputInterface was not found. Maybe you did not declare it correctly or list all dependencies?
The issue could also be caused by a filter entry in the build configuration.
If the path has been excluded in your configuration, e.g. filter:
dependency_paths: ["lib/*"]
For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths ![]() |
|||||
14 | use Symfony\Component\Console\Output\OutputInterface; |
||||
0 ignored issues
–
show
The type
Symfony\Component\Console\Output\OutputInterface was not found. Maybe you did not declare it correctly or list all dependencies?
The issue could also be caused by a filter entry in the build configuration.
If the path has been excluded in your configuration, e.g. filter:
dependency_paths: ["lib/*"]
For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths ![]() |
|||||
15 | |||||
16 | /** |
||||
17 | * Class AggregateCommand |
||||
18 | * @package Xima\DepmonBundle\Command |
||||
19 | */ |
||||
20 | class AggregateCommand extends ContainerAwareCommand |
||||
0 ignored issues
–
show
The class
Symfony\Bundle\Framework...d\ContainerAwareCommand has been deprecated: since Symfony 4.2, use {@see Command} instead.
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
![]() |
|||||
21 | { |
||||
22 | |||||
23 | /** |
||||
24 | * @var Aggregator |
||||
25 | */ |
||||
26 | private $aggregator; |
||||
27 | |||||
28 | /** |
||||
29 | * @var Cache |
||||
30 | */ |
||||
31 | private $cache; |
||||
32 | |||||
33 | /** |
||||
34 | * @var LoggerInterface |
||||
35 | */ |
||||
36 | private $logger; |
||||
37 | |||||
38 | public function __construct(Aggregator $aggregator, Cache $cache, LoggerInterface $logger) |
||||
39 | { |
||||
40 | $this->aggregator = $aggregator; |
||||
41 | $this->cache = $cache; |
||||
42 | $this->logger = $logger; |
||||
43 | |||||
44 | parent::__construct(); |
||||
45 | } |
||||
46 | |||||
47 | protected function configure() |
||||
48 | { |
||||
49 | $this |
||||
50 | // the name of the command (the part after "bin/console") |
||||
51 | ->setName('depmon:aggregate') |
||||
52 | |||||
53 | // the short description shown while running "php bin/console list" |
||||
54 | ->setDescription('Aggregate command.') |
||||
55 | |||||
56 | // the full command description shown when running the command with |
||||
57 | // the "--help" option |
||||
58 | ->setHelp('This command is fetching all composer information of every project.') |
||||
59 | ; |
||||
60 | } |
||||
61 | |||||
62 | protected function execute(InputInterface $input, OutputInterface $output) |
||||
63 | { |
||||
64 | |||||
65 | $io = new SymfonyStyle($input, $output); |
||||
66 | |||||
67 | $io->text("<fg=red>██████╗ ███████╗██████╗ ███╗ ███╗ ██████╗ ███╗ ██╗</>"); |
||||
68 | $io->text("<fg=red>██╔══██╗██╔════╝██╔══██╗████╗ ████║██╔═══██╗████╗ ██║</>"); |
||||
69 | $io->text("<fg=red>██║ ██║█████╗ ██████╔╝██╔████╔██║██║ ██║██╔██╗ ██║</>"); |
||||
70 | $io->text("<fg=red>██║ ██║██╔══╝ ██╔═══╝ ██║╚██╔╝██║██║ ██║██║╚██╗██║</>"); |
||||
71 | $io->text("<fg=red>██████╔╝███████╗██║ ██║ ╚═╝ ██║╚██████╔╝██║ ╚████║</>"); |
||||
72 | $io->text("<fg=red>╚═════╝ ╚══════╝╚═╝ ╚═╝ ╚═╝ ╚═════╝ ╚═╝ ╚═══╝</>"); |
||||
73 | |||||
74 | $io->title("Aggregate project data"); |
||||
75 | |||||
76 | // $projects = Yaml::parseFile('config/depmon.projects.yaml'); |
||||
77 | $projects = $this->getContainer()->getParameter('xima_depmon.projects'); |
||||
78 | |||||
79 | $progressBar = new ProgressBar($output, count($projects)); |
||||
80 | $progressBar->setFormat('verbose'); |
||||
81 | |||||
82 | $projectCount = count($projects); |
||||
83 | $io->text("Fetching data for $projectCount projects ..."); |
||||
84 | |||||
85 | |||||
86 | $dependencyCount = 0; |
||||
87 | |||||
88 | foreach ($projects as $project) { |
||||
89 | try { |
||||
90 | |||||
91 | $data = $this->aggregator->fetchProjectData($project, $this->logger); |
||||
92 | $count = count($data['dependencies']); |
||||
93 | $requiredCount = $data['meta']['requiredPackagesCount']; |
||||
94 | $requiredStatesCount = $data['meta']['requiredStatesCount']; |
||||
95 | $dependencyCount += $count; |
||||
96 | |||||
97 | $this->cache->set($project['name'], $data); |
||||
98 | |||||
99 | switch ($data['meta']['projectState']) { |
||||
100 | case 1: |
||||
101 | $projectState = "<fg=green>up to date</>"; |
||||
102 | break; |
||||
103 | case 2: |
||||
104 | $projectState = "<fg=yellow>up to date</>"; |
||||
105 | break; |
||||
106 | case 3: |
||||
107 | default: |
||||
108 | $projectState = "<fg=red>out of date</>"; |
||||
109 | break; |
||||
110 | case 4: |
||||
111 | $projectState = "<fg=black>insecure</>"; |
||||
112 | break; |
||||
113 | } |
||||
114 | |||||
115 | $progressBar->advance(); |
||||
116 | $output->writeln(" <fg=blue;options=bold>[" . $project['name'] . "]</> $count dependencies, $requiredCount required (<fg=green>$requiredStatesCount[1]</>, <fg=yellow>$requiredStatesCount[2]</>, <fg=red>$requiredStatesCount[3]</>, <fg=black>$requiredStatesCount[4]</>) ==> " . $projectState); |
||||
117 | |||||
118 | } catch (InvalidArgumentException $e) { |
||||
0 ignored issues
–
show
Coding Style
Comprehensibility
introduced
by
|
|||||
119 | |||||
120 | } |
||||
121 | |||||
122 | $this->aggregator->clearProjectData($project); |
||||
123 | } |
||||
124 | |||||
125 | |||||
126 | $metadata = [ |
||||
127 | 'time' => time(), |
||||
128 | 'dependencyCount' => $dependencyCount |
||||
129 | ]; |
||||
130 | |||||
131 | $this->cache->set('metadata', $metadata); |
||||
132 | } |
||||
133 | } |
The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g.
excluded_paths: ["lib/*"]
, you can move it to the dependency path list as follows:For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths