-
-
Notifications
You must be signed in to change notification settings - Fork 223
/
Copy pathvalidator.php
138 lines (109 loc) · 4.97 KB
/
validator.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
<?php
// validates that the information of this repository is valid
if (!is_file($autoloader = __DIR__.'/vendor/autoload.php')) {
echo "Dependencies are not installed, please run 'composer install' first!\n";
exit(1);
}
require $autoloader;
use Composer\Config;
use Composer\IO\NullIO;
use Composer\Repository\ComposerRepository;
use Composer\Repository\RepositoryInterface;
use Symfony\Component\Console\Application;
use Symfony\Component\Console\Command\Command;
use Symfony\Component\Console\Input\InputDefinition;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Output\OutputInterface;
use Symfony\Component\Console\Style\SymfonyStyle;
use Symfony\Component\Yaml\Exception\ParseException;
use Symfony\Component\Yaml\Parser;
final class Validate extends Command
{
private const EXIT_SUCCESSFUL = 0;
private const EXIT_ERROR = 1;
private $yamlParser;
public function __construct()
{
parent::__construct('validate');
$this->yamlParser = new Parser();
}
protected function execute(InputInterface $input, OutputInterface $output)
{
$io = new SymfonyStyle($input, $output);
// check that the YAML code is valid for all files
$yamlFiles = array_merge([__DIR__.'/projects.yml'], glob(__DIR__.'/projects/*.yml', GLOB_NOSORT));
foreach ($yamlFiles as $filePath) {
try {
$this->yamlParser->parseFile($filePath);
} catch (ParseException $e) {
$io->error(sprintf('The "%s" file does not have valid YAML syntax.', $filePath));
return self::EXIT_ERROR;
}
}
$projects = $this->yamlParser->parseFile(__DIR__.'/projects.yml');
// check that project detail files use '.yml' extension instead of '.yaml'
$filesWithYamlExtension = glob(__DIR__.'/projects/*.yaml', GLOB_NOSORT);
if (count($filesWithYamlExtension) > 0) {
$io->error(sprintf('All the YAML files in the "projects/" directory must use ".yml" as extension instead of ".yaml". The following files must change their extension: %s.', implode(', ', $filesWithYamlExtension)));
return self::EXIT_ERROR;
}
// check that projects are only in one category (e.g. a project can't be in 'cms' and 'default')
$allProjectSlugs = [];
foreach ($projects as $category => $projectSlugs) {
foreach ($projectSlugs as $projectSlug) {
if (\in_array($projectSlug, $allProjectSlugs, true)) {
$io->error(sprintf('The "%s" project slug of "%s" category is included in another category (each projet can only be included in a single category.', $projectSlug, $category));
return self::EXIT_ERROR;
}
$allProjectSlugs[] = $projectSlug;
}
}
// check that if a project is listed in the index, it defines a separate file with its information
foreach ($allProjectSlugs as $projectSlug) {
$expectedProjectFile = sprintf(__DIR__.'/projects/%s.yml', $projectSlug);
if (!file_exists($expectedProjectFile)) {
$io->error(sprintf('The "%s" project is missing a file with its detailed description in "%s".', $projectSlug, $expectedProjectFile));
return self::EXIT_ERROR;
}
}
// check that all project files correspond to a project listed in the index file
foreach (glob(__DIR__.'/projects/*.yml', GLOB_NOSORT) as $filePath) {
$projectSlug = basename($filePath,'.yml');
if (!\in_array($projectSlug, $allProjectSlugs, true)) {
$io->error(sprintf('The "%s" file refers to a project called "%s" which is not listed in the main projects.yml file.', $filePath, $projectSlug));
return self::EXIT_ERROR;
}
}
// check that ech project defines its own logo file
foreach (glob(__DIR__.'/projects/*.yml', GLOB_NOSORT) as $filePath) {
$projectSlug = basename($filePath,'.yml');
if (!file_exists(str_replace('.yml', '.png', $filePath))) {
$io->error(sprintf('The "%s" project does not define its logo in a "%s.png" file.', $projectSlug, $projectSlug));
return self::EXIT_ERROR;
}
}
$io->success('All data is valid.');
return self::EXIT_SUCCESSFUL;
}
}
final class Validator extends Application
{
protected function getCommandName(InputInterface $input): ?string
{
return 'validate';
}
protected function getDefaultCommands(): array
{
$defaultCommands = parent::getDefaultCommands();
$defaultCommands[] = new Validate();
return $defaultCommands;
}
public function getDefinition(): InputDefinition
{
$inputDefinition = parent::getDefinition();
$inputDefinition->setArguments();
return $inputDefinition;
}
}
$application = new Validator();
$application->run();