Fixed phpstan issues

This commit is contained in:
Jan Böhmer 2026-02-02 23:26:18 +01:00
parent a755287c3b
commit cad5261aba
6 changed files with 11 additions and 10 deletions

View file

@ -6,6 +6,9 @@ parameters:
- src - src
# - tests # - tests
banned_code:
non_ignorable: false # Allow to ignore some banned code
excludePaths: excludePaths:
- src/DataTables/Adapter/* - src/DataTables/Adapter/*
- src/Configuration/* - src/Configuration/*
@ -61,3 +64,6 @@ parameters:
# Ignore error of unused WithPermPresetsTrait, as it is used in the migrations which are not analyzed by Phpstan # Ignore error of unused WithPermPresetsTrait, as it is used in the migrations which are not analyzed by Phpstan
- '#Trait App\\Migration\\WithPermPresetsTrait is used zero times and is not analysed#' - '#Trait App\\Migration\\WithPermPresetsTrait is used zero times and is not analysed#'
-
message: '#Should not use function "shell_exec"#'
path: src/Services/System/UpdateExecutor.php

View file

@ -106,7 +106,7 @@ class MaintenanceModeCommand extends Command
if ($enable) { if ($enable) {
// Use provided message or fallback to a default English message // Use provided message or fallback to a default English message
$reason = is_string($message) && $message !== '' $reason = is_string($message)
? $message ? $message
: 'The system is temporarily unavailable due to maintenance.'; : 'The system is temporarily unavailable due to maintenance.';

View file

@ -28,8 +28,6 @@ use Symfony\Component\Process\Process;
class CommandRunHelper class CommandRunHelper
{ {
private UpdateExecutor $updateExecutor;
public function __construct( public function __construct(
#[Autowire(param: 'kernel.project_dir')] private readonly string $project_dir #[Autowire(param: 'kernel.project_dir')] private readonly string $project_dir
) )

View file

@ -33,8 +33,6 @@ use Version\Version;
*/ */
class UpdateAvailableFacade class UpdateAvailableFacade
{ {
private const API_URL = 'https://api.github.com/repos/Part-DB/Part-DB-server/releases/latest';
private const CACHE_KEY = 'uam_latest_version'; private const CACHE_KEY = 'uam_latest_version';
private const CACHE_TTL = 60 * 60 * 24 * 2; // 2 day private const CACHE_TTL = 60 * 60 * 24 * 2; // 2 day

View file

@ -145,15 +145,12 @@ class UpdateChecker
/** /**
* Get all available releases from GitHub (cached). * Get all available releases from GitHub (cached).
* *
* @return array<array{version: string, tag: string, name: string, url: string, published_at: string, body: string, prerelease: bool, assets: array}> * @return array<array{version: string, tag: string, name: string, url: string, published_at: string, body: string, prerelease: bool, draft:bool, assets: array, tarball_url: ?string, zipball_url: ?string}>
*/ */
public function getAvailableReleases(int $limit = 10): array public function getAvailableReleases(int $limit = 10): array
{ {
if (!$this->privacySettings->checkForUpdates) { if (!$this->privacySettings->checkForUpdates) {
return [ //If we don't want to check for updates, we can return dummy data return [];
'version' => '0.0.1',
'url' => 'update-checking-disabled'
];
} }
return $this->updateCache->get(self::CACHE_KEY_RELEASES, function (ItemInterface $item) use ($limit) { return $this->updateCache->get(self::CACHE_KEY_RELEASES, function (ItemInterface $item) use ($limit) {

View file

@ -863,6 +863,8 @@ class UpdateExecutor
// Execute in background using shell_exec for proper detachment // Execute in background using shell_exec for proper detachment
// shell_exec with & runs the command in background // shell_exec with & runs the command in background
//@php-ignore-next-line We really need to use shell_exec here
$output = shell_exec($command); $output = shell_exec($command);
// Give it a moment to start // Give it a moment to start