modified version handling
All checks were successful
CI/CD Pipeline / deploy (push) Successful in 24s
CI/CD Pipeline / promote_stable (push) Successful in 2s

This commit is contained in:
2026-02-24 19:29:04 +01:00
parent 6a2316c6f4
commit 16e0444fa3
3 changed files with 47 additions and 10 deletions

View File

@@ -10,15 +10,15 @@ class VersionFetch extends Command
{
protected $signature = 'version:fetch';
protected $description = 'Update the build number based on the git commit count of master.';
protected $description = 'Sync version/build metadata into settings using composer.json version and git build count.';
public function handle(): int
{
$version = Setting::where('key', 'version')->value('value');
$version = $this->resolveComposerVersion();
$build = $this->resolveBuildCount();
if ($version === null) {
$this->error('Unable to determine version from settings.');
$this->error('Unable to determine version from composer.json.');
return self::FAILURE;
}
@@ -27,21 +27,56 @@ class VersionFetch extends Command
return self::FAILURE;
}
Setting::updateOrCreate(
['key' => 'version'],
['value' => $version],
);
Setting::updateOrCreate(
['key' => 'build'],
['value' => (string) $build],
);
if (!$this->syncComposerMetadata($version, $build)) {
if (!$this->syncComposerBuild($build)) {
$this->error('Failed to sync version/build to composer.json.');
return self::FAILURE;
}
$this->info("Build number updated to {$build}.");
$this->info("Version/build synced: {$version} (build {$build}).");
return self::SUCCESS;
}
private function resolveComposerVersion(): ?string
{
$composerPath = base_path('composer.json');
if (!is_file($composerPath) || !is_readable($composerPath)) {
return null;
}
$raw = file_get_contents($composerPath);
if ($raw === false) {
return null;
}
$data = json_decode($raw, true);
if (!is_array($data)) {
return null;
}
$version = trim((string) ($data['version'] ?? ''));
if ($version === '') {
return null;
}
if (!preg_match('/^\d+\.\d+(?:\.\d+)?(?:[-._][0-9A-Za-z.-]+)?$/', $version)) {
return null;
}
return $version;
}
private function resolveBuildCount(): ?int
{
$commands = [
@@ -64,7 +99,7 @@ class VersionFetch extends Command
return null;
}
private function syncComposerMetadata(string $version, int $build): bool
private function syncComposerBuild(int $build): bool
{
$composerPath = base_path('composer.json');
@@ -82,7 +117,6 @@ class VersionFetch extends Command
return false;
}
$data['version'] = $version;
$data['build'] = (string) $build;
$encoded = json_encode($data, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES);