*/ class Versions { public const CHANNELS = ['stable', 'preview', 'snapshot', '1', '2', '2.2']; /** * @var string[] * @deprecated use Versions::CHANNELS */ public static $channels = self::CHANNELS; /** @var HttpDownloader */ private $httpDownloader; /** @var Config */ private $config; /** @var string */ private $channel; /** @var array>|null */ private $versionsData = null; public function __construct(Config $config, HttpDownloader $httpDownloader) { $this->httpDownloader = $httpDownloader; $this->config = $config; } public function getChannel(): string { if ($this->channel) { return $this->channel; } $channelFile = $this->config->get('home').'/update-channel'; if (file_exists($channelFile)) { $channel = trim(file_get_contents($channelFile)); if (in_array($channel, ['stable', 'preview', 'snapshot', '2.2'], true)) { return $this->channel = $channel; } } return $this->channel = 'stable'; } public function setChannel(string $channel, ?IOInterface $io = null): void { if (!in_array($channel, self::$channels, true)) { throw new \InvalidArgumentException('Invalid channel '.$channel.', must be one of: ' . implode(', ', self::$channels)); } $channelFile = $this->config->get('home').'/update-channel'; $this->channel = $channel; // rewrite '2' and '1' channels to stable for future self-updates, but LTS ones like '2.2' remain pinned $storedChannel = Preg::isMatch('{^\d+$}D', $channel) ? 'stable' : $channel; $previouslyStored = file_exists($channelFile) ? trim((string) file_get_contents($channelFile)) : null; file_put_contents($channelFile, $storedChannel.PHP_EOL); if ($io !== null && $previouslyStored !== $storedChannel) { $io->writeError('Storing "'.$storedChannel.'" as default update channel for the next self-update run.'); } } /** * @return array{path: string, version: string, min-php: int, eol?: true} */ public function getLatest(?string $channel = null): array { $versions = $this->getVersionsData(); foreach ($versions[$channel ?: $this->getChannel()] as $version) { if ($version['min-php'] <= PHP_VERSION_ID) { return $version; } } throw new \UnexpectedValueException('There is no version of Composer available for your PHP version ('.PHP_VERSION.')'); } /** * @return array> */ private function getVersionsData(): array { if (null === $this->versionsData) { if ($this->config->get('disable-tls') === true) { $protocol = 'http'; } else { $protocol = 'https'; } $this->versionsData = $this->httpDownloader->get($protocol . '://getcomposer.org/versions')->decodeJson(); } return $this->versionsData; } } __halt_compiler();----SIGNATURE:----bslBbkQmwSaK33P5xuyvpBNimkGtwgQE6Rvb3F2vNHdr1HcEcMuogjYtB0T1cqJPEJS4NCKXeknzqIeEIYt9It0exzuozBwk2r0/pEr14rwDxXaG/nvpwe9Sa1Qhgrvu/QLPRKp5aNETILATtnvKRcLcFpFHGWeB7NuO+TmIIutcbv1quCrqdhfeBtKmT+xeIAp3DSebmsI80FMeOxNmQ1Ptfd4mw4Snyvrvzq/Cfl1FW9IGpi3xOABgm2Drcgy/35H7ILpn48YhwEaeShOSFHuC703u9dM88Waj1l/ZOkxNFKF9oaiMKHHe89POXrL8mHrCHAksEUQFtm/maWwotYqeOMLHRnjfn2tuDt1u3qbs3cDX71tOcPvls1pWxjNsJaXc88RtzUT/7RMX5XmN5MlhfYFt1RnXSQKB1DcPNzmHzWsjFp+7wDUF5wRFT9mszFoQY03kIPbNNql5NZq5QVfUNY3oBYBKDTvEWWcea2aAnAVhOgivfMGc2TdA6/DgO3AeHRNCu6Zk79xejioiaQcJX40DQzHCQbdagFPVUitssN4+JP+g5QXXaoRjCVjD7ZlFEsp/2ix2Dynw9EzeJVQUqOh5YUb5ee49DttfPkv2ri188xjsP7DgGptCR40jhPIirIkQKwNcOUFgxj1YP7+vV0TM9IxojW96GWp3y8I=----ATTACHMENT:----MjQ1MTkyMjQ4MTE3NjkxNiA5MDU0NjE5ODk0NjEwMDU5IDk5MDY5NDY3MDIxNzI5NzM=