src/Utility/Security.php
<?php
declare(strict_types=1);
namespace EliasHaeussler\ComposerUpdateCheck\Utility;
/*
* This file is part of the Composer package "eliashaeussler/composer-update-check".
*
* Copyright (C) 2020 Elias Häußler <elias@haeussler.dev>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
use EliasHaeussler\ComposerUpdateCheck\Package\OutdatedPackage;
use EliasHaeussler\ComposerUpdateCheck\Package\UpdateCheckResult;
use EliasHaeussler\ComposerUpdateCheck\Security\ScanResult;
use EliasHaeussler\ComposerUpdateCheck\Security\SecurityScanner;
/**
* Security.
*
* @author Elias Häußler <elias@haeussler.dev>
* @license GPL-3.0-or-later
*/
class Security
{
/**
* @param OutdatedPackage[] $outdatedPackages
*/
public static function scan(array $outdatedPackages): ScanResult
{
$securityChecker = new SecurityScanner();
return $securityChecker->scan($outdatedPackages);
}
public static function scanAndOverlayResult(UpdateCheckResult $result): UpdateCheckResult
{
$outdatedPackages = $result->getOutdatedPackages();
$scanResult = static::scan($outdatedPackages);
foreach ($outdatedPackages as $outdatedPackage) {
if ($scanResult->isInsecure($outdatedPackage)) {
$outdatedPackage->setInsecure(true);
}
}
return $result;
}
}