-
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathChangelogShowCommand.php
More file actions
124 lines (112 loc) · 4.05 KB
/
ChangelogShowCommand.php
File metadata and controls
124 lines (112 loc) · 4.05 KB
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
<?php
declare(strict_types=1);
/**
* Fast Forward Development Tools for PHP projects.
*
* This file is part of fast-forward/dev-tools project.
*
* @author Felipe Sayão Lobato Abreu <github@mentordosnerds.com>
* @license https://opensource.org/licenses/MIT MIT License
*
* @see https://github.com/php-fast-forward/
* @see https://github.com/php-fast-forward/dev-tools
* @see https://github.com/php-fast-forward/dev-tools/issues
* @see https://php-fast-forward.github.io/dev-tools/
* @see https://datatracker.ietf.org/doc/html/rfc2119
*/
namespace FastForward\DevTools\Console\Command;
use FastForward\DevTools\Console\Command\Traits\LogsCommandResults;
use Throwable;
use Composer\Command\BaseCommand;
use FastForward\DevTools\Changelog\Manager\ChangelogManagerInterface;
use FastForward\DevTools\Console\Input\HasJsonOption;
use FastForward\DevTools\Filesystem\FilesystemInterface;
use Psr\Log\LoggerInterface;
use Symfony\Component\Console\Attribute\AsCommand;
use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Output\OutputInterface;
/**
* Prints the rendered notes body for a released changelog version.
*/
#[AsCommand(name: 'changelog:show', description: 'Prints the notes body for a released changelog version.')]
final class ChangelogShowCommand extends BaseCommand implements LoggerAwareCommandInterface
{
use HasJsonOption;
use LogsCommandResults;
/**
* @param FilesystemInterface $filesystem
* @param ChangelogManagerInterface $changelogManager
* @param LoggerInterface $logger
*/
public function __construct(
private readonly FilesystemInterface $filesystem,
private readonly ChangelogManagerInterface $changelogManager,
private readonly LoggerInterface $logger,
) {
parent::__construct();
}
/**
* Configures the show command arguments and options.
*/
protected function configure(): void
{
$this->setHelp(
'This command renders the body of one released changelog section so it can be reused for GitHub'
. ' release notes.'
);
$this->addJsonOption()
->addArgument(
name: 'version',
mode: InputArgument::REQUIRED,
description: 'The released version to render.',
)
->addOption(
name: 'file',
mode: InputOption::VALUE_REQUIRED,
description: 'Path to the changelog file.',
default: 'CHANGELOG.md',
);
}
/**
* Prints the rendered release notes body.
*
* @param InputInterface $input
* @param OutputInterface $output
*/
protected function execute(InputInterface $input, OutputInterface $output): int
{
try {
$version = (string) $input->getArgument('version');
$file = (string) $input->getOption('file');
$releaseNotes = $this->changelogManager->renderReleaseNotes(
$this->filesystem->getAbsolutePath($file),
$version,
);
// This command feeds redirected release-notes files in changelog.yml,
// so plain-text mode MUST keep writing the rendered body directly.
if (! $this->isJsonOutput($input)) {
$output->write($releaseNotes);
return self::SUCCESS;
}
return $this->success(
$releaseNotes,
$input,
[
'version' => $version,
'release_notes' => $releaseNotes,
],
);
} catch (Throwable $throwable) {
return $this->failure(
'Unable to render changelog release notes.',
$input,
[
'exception_message' => $throwable->getMessage(),
],
(string) $input->getOption('file'),
);
}
}
}