From e013ef7abe5ec38cab4aa35c042fe5594bfffee3 Mon Sep 17 00:00:00 2001 From: Miraty Date: Fri, 7 Jul 2023 22:33:10 +0200 Subject: [PATCH] Update composer dependencies --- CHANGELOG.md | 6 +- README.md | 2 +- vendor/autoload.php | 19 +- vendor/bacon/bacon-qr-code/composer.json | 6 + vendor/bacon/bacon-qr-code/phpunit.xml.dist | 13 + .../src/Common/CharacterSetEci.php | 3 + .../src/Common/FormatInformation.php | 2 +- .../bacon/bacon-qr-code/src/Common/Mode.php | 3 + .../bacon-qr-code/src/Encoder/Encoder.php | 2 +- .../src/Renderer/Image/SvgImageBackEnd.php | 4 +- .../Module/EdgeIterator/EdgeIterator.php | 2 +- .../src/Renderer/Path/EllipticArc.php | 2 +- .../test/Integration/ImagickRenderingTest.php | 9 + vendor/bin/lessc | 10 +- vendor/composer/ClassLoader.php | 137 +-- vendor/composer/InstalledVersions.php | 17 +- vendor/composer/autoload_real.php | 8 +- vendor/composer/autoload_static.php | 10 +- vendor/composer/installed.json | 84 +- vendor/composer/installed.php | 28 +- vendor/composer/platform_check.php | 4 +- .../dasprid/enum/.github/workflows/tests.yml | 47 + vendor/dasprid/enum/README.md | 30 +- vendor/dasprid/enum/composer.json | 5 +- vendor/dasprid/enum/src/EnumMap.php | 42 +- vendor/endroid/qr-code/LICENSE | 2 +- vendor/endroid/qr-code/README.md | 50 +- vendor/endroid/qr-code/assets/blackfire.png | Bin 0 -> 28753 bytes vendor/endroid/qr-code/composer.json | 10 +- .../endroid/qr-code/src/Builder/Builder.php | 9 +- .../qr-code/src/Builder/BuilderInterface.php | 2 +- vendor/endroid/qr-code/src/Color/Color.php | 22 +- .../qr-code/src/Color/ColorInterface.php | 2 + .../endroid/qr-code/src/Encoding/Encoding.php | 9 +- .../src/Exception/ValidationException.php | 23 + .../qr-code/src/ImageData/LabelImageData.php | 11 +- .../qr-code/src/ImageData/LogoImageData.php | 39 +- .../endroid/qr-code/src/Label/Font/Font.php | 16 +- .../qr-code/src/Label/Font/NotoSans.php | 8 +- .../qr-code/src/Label/Font/OpenSans.php | 8 +- vendor/endroid/qr-code/src/Label/Label.php | 20 +- .../qr-code/src/Label/Margin/Margin.php | 17 +- vendor/endroid/qr-code/src/Logo/Logo.php | 25 +- .../qr-code/src/Logo/LogoInterface.php | 4 +- vendor/endroid/qr-code/src/Matrix/Matrix.php | 13 +- vendor/endroid/qr-code/src/QrCode.php | 22 +- .../endroid/qr-code/src/WritableInterface.php | 7 - .../qr-code/src/Writer/AbstractGdWriter.php | 205 ++++ .../qr-code/src/Writer/BinaryWriter.php | 2 +- .../qr-code/src/Writer/ConsoleWriter.php | 23 + .../qr-code/src/Writer/DebugWriter.php | 8 +- .../endroid/qr-code/src/Writer/EpsWriter.php | 4 +- .../endroid/qr-code/src/Writer/GifWriter.php | 23 + .../endroid/qr-code/src/Writer/PdfWriter.php | 10 +- .../endroid/qr-code/src/Writer/PngWriter.php | 218 +--- .../src/Writer/Result/AbstractResult.php | 12 + .../src/Writer/Result/BinaryResult.php | 12 +- .../src/Writer/Result/ConsoleResult.php | 69 ++ .../qr-code/src/Writer/Result/DebugResult.php | 24 +- .../qr-code/src/Writer/Result/EpsResult.php | 15 +- .../qr-code/src/Writer/Result/GdResult.php | 32 + .../qr-code/src/Writer/Result/GifResult.php | 21 + .../qr-code/src/Writer/Result/PdfResult.php | 12 +- .../qr-code/src/Writer/Result/PngResult.php | 21 +- .../src/Writer/Result/ResultInterface.php | 4 + .../qr-code/src/Writer/Result/SvgResult.php | 15 +- .../qr-code/src/Writer/Result/WebPResult.php | 35 + .../endroid/qr-code/src/Writer/SvgWriter.php | 17 +- .../endroid/qr-code/src/Writer/WebPWriter.php | 29 + .../qr-code/src/Writer/WriterInterface.php | 4 +- vendor/wikimedia/less.php/API.md | 197 ++++ vendor/wikimedia/less.php/CHANGES.md | 133 ++- vendor/wikimedia/less.php/CODE_OF_CONDUCT.md | 1 + vendor/wikimedia/less.php/LICENSE | 324 +++--- vendor/wikimedia/less.php/NOTICE.txt | 18 + vendor/wikimedia/less.php/README.md | 328 +----- vendor/wikimedia/less.php/SECURITY.md | 5 + vendor/wikimedia/less.php/bin/lessc | 2 +- vendor/wikimedia/less.php/composer.json | 49 - vendor/wikimedia/less.php/lessc.inc.php | 26 +- .../less.php/lib/Less/Autoloader.php | 38 +- vendor/wikimedia/less.php/lib/Less/Cache.php | 97 +- vendor/wikimedia/less.php/lib/Less/Colors.php | 319 +++--- .../less.php/lib/Less/Configurable.php | 12 +- .../less.php/lib/Less/Environment.php | 58 +- .../less.php/lib/Less/Exception/Chunk.php | 36 +- .../less.php/lib/Less/Exception/Compiler.php | 3 - .../less.php/lib/Less/Exception/Parser.php | 43 +- .../wikimedia/less.php/lib/Less/Functions.php | 212 ++-- vendor/wikimedia/less.php/lib/Less/Mime.php | 37 +- vendor/wikimedia/less.php/lib/Less/Output.php | 14 +- .../less.php/lib/Less/Output/Mapped.php | 18 +- vendor/wikimedia/less.php/lib/Less/Parser.php | 1018 +++++++++-------- .../less.php/lib/Less/SourceMap/Base64VLQ.php | 38 +- .../less.php/lib/Less/SourceMap/Generator.php | 48 +- vendor/wikimedia/less.php/lib/Less/Tree.php | 23 +- .../less.php/lib/Less/Tree/Alpha.php | 6 +- .../less.php/lib/Less/Tree/Anonymous.php | 12 +- .../less.php/lib/Less/Tree/Assignment.php | 6 +- .../less.php/lib/Less/Tree/Attribute.php | 6 +- .../wikimedia/less.php/lib/Less/Tree/Call.php | 45 +- .../less.php/lib/Less/Tree/Color.php | 58 +- .../less.php/lib/Less/Tree/Comment.php | 12 +- .../less.php/lib/Less/Tree/Condition.php | 22 +- .../less.php/lib/Less/Tree/DefaultFunc.php | 6 +- .../lib/Less/Tree/DetachedRuleset.php | 6 +- .../less.php/lib/Less/Tree/Dimension.php | 26 +- .../less.php/lib/Less/Tree/Directive.php | 8 +- .../less.php/lib/Less/Tree/Element.php | 41 +- .../less.php/lib/Less/Tree/Expression.php | 15 +- .../less.php/lib/Less/Tree/Extend.php | 24 +- .../less.php/lib/Less/Tree/Import.php | 66 +- .../less.php/lib/Less/Tree/Javascript.php | 12 +- .../less.php/lib/Less/Tree/Keyword.php | 10 +- .../less.php/lib/Less/Tree/Media.php | 62 +- .../less.php/lib/Less/Tree/Mixin/Call.php | 32 +- .../lib/Less/Tree/Mixin/Definition.php | 41 +- .../less.php/lib/Less/Tree/NameValue.php | 14 +- .../less.php/lib/Less/Tree/Negative.php | 8 +- .../less.php/lib/Less/Tree/Operation.php | 8 +- .../less.php/lib/Less/Tree/Paren.php | 10 +- .../less.php/lib/Less/Tree/Quoted.php | 8 +- .../wikimedia/less.php/lib/Less/Tree/Rule.php | 17 +- .../less.php/lib/Less/Tree/Ruleset.php | 355 ++++-- .../less.php/lib/Less/Tree/RulesetCall.php | 10 +- .../less.php/lib/Less/Tree/Selector.php | 34 +- .../lib/Less/Tree/UnicodeDescriptor.php | 10 +- .../wikimedia/less.php/lib/Less/Tree/Unit.php | 28 +- .../lib/Less/Tree/UnitConversions.php | 20 +- .../wikimedia/less.php/lib/Less/Tree/Url.php | 13 +- .../less.php/lib/Less/Tree/Value.php | 11 +- .../less.php/lib/Less/Tree/Variable.php | 17 +- .../wikimedia/less.php/lib/Less/Version.php | 5 +- .../wikimedia/less.php/lib/Less/Visitor.php | 18 +- .../lib/Less/Visitor/extendFinder.php | 18 +- .../lib/Less/Visitor/joinSelector.php | 39 +- .../lib/Less/Visitor/processExtends.php | 46 +- .../less.php/lib/Less/Visitor/toCSS.php | 53 +- .../less.php/lib/Less/VisitorReplacing.php | 12 +- 139 files changed, 3217 insertions(+), 2779 deletions(-) create mode 100644 vendor/bacon/bacon-qr-code/phpunit.xml.dist create mode 100644 vendor/dasprid/enum/.github/workflows/tests.yml create mode 100644 vendor/endroid/qr-code/assets/blackfire.png create mode 100644 vendor/endroid/qr-code/src/Exception/ValidationException.php delete mode 100644 vendor/endroid/qr-code/src/WritableInterface.php create mode 100644 vendor/endroid/qr-code/src/Writer/AbstractGdWriter.php create mode 100644 vendor/endroid/qr-code/src/Writer/ConsoleWriter.php create mode 100644 vendor/endroid/qr-code/src/Writer/GifWriter.php create mode 100644 vendor/endroid/qr-code/src/Writer/Result/ConsoleResult.php create mode 100644 vendor/endroid/qr-code/src/Writer/Result/GdResult.php create mode 100644 vendor/endroid/qr-code/src/Writer/Result/GifResult.php create mode 100644 vendor/endroid/qr-code/src/Writer/Result/WebPResult.php create mode 100644 vendor/endroid/qr-code/src/Writer/WebPWriter.php create mode 100644 vendor/wikimedia/less.php/API.md create mode 100644 vendor/wikimedia/less.php/CODE_OF_CONDUCT.md create mode 100644 vendor/wikimedia/less.php/NOTICE.txt create mode 100644 vendor/wikimedia/less.php/SECURITY.md delete mode 100644 vendor/wikimedia/less.php/composer.json diff --git a/CHANGELOG.md b/CHANGELOG.md index fff5a80..cec593d 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -11,6 +11,10 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/). * Indonesian localization * Basque localization +### Changed + +* Update dependencies + ## 2.0.0 - 2022-06-07 ### Added @@ -24,7 +28,7 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/). * Output generated QR code with `data:` URI * Change the QR code generation library * Use less.php instead of lesserphp -* Use the prefers-color-scheme CSS feature to let the client choose its prefered theme (dark/light) +* Use the prefers-color-scheme CSS feature to let the client choose its preferred theme (dark/light) ### Removed diff --git a/README.md b/README.md index c52e4bd..758c9df 100755 --- a/README.md +++ b/README.md @@ -10,7 +10,7 @@ A LibreQR instance is available at . ### Generic -Just place this source code in a Web server with PHP7.4+, extensions `gd`, `mbstring` and `iconv`, and writing rights on the `css/` directory. +Just place this source code in a Web server with PHP8.0+, extensions `gd`, `mbstring` and `iconv`, and writing rights on the `css/` directory. #### Security hardening diff --git a/vendor/autoload.php b/vendor/autoload.php index 79bfa69..52e3daf 100644 --- a/vendor/autoload.php +++ b/vendor/autoload.php @@ -3,10 +3,23 @@ // autoload.php @generated by Composer if (PHP_VERSION_ID < 50600) { - echo 'Composer 2.3.0 dropped support for autoloading on PHP <5.6 and you are running '.PHP_VERSION.', please upgrade PHP or use Composer 2.2 LTS via "composer self-update --2.2". Aborting.'.PHP_EOL; - exit(1); + if (!headers_sent()) { + header('HTTP/1.1 500 Internal Server Error'); + } + $err = 'Composer 2.3.0 dropped support for autoloading on PHP <5.6 and you are running '.PHP_VERSION.', please upgrade PHP or use Composer 2.2 LTS via "composer self-update --2.2". Aborting.'.PHP_EOL; + if (!ini_get('display_errors')) { + if (PHP_SAPI === 'cli' || PHP_SAPI === 'phpdbg') { + fwrite(STDERR, $err); + } elseif (!headers_sent()) { + echo $err; + } + } + trigger_error( + $err, + E_USER_ERROR + ); } require_once __DIR__ . '/composer/autoload_real.php'; -return ComposerAutoloaderInit6bb82695b2f28e8ee61f74ae2d5c5202::getLoader(); +return ComposerAutoloaderInitd4957e04ba4dff37d0ecbf0a4b59e14a::getLoader(); diff --git a/vendor/bacon/bacon-qr-code/composer.json b/vendor/bacon/bacon-qr-code/composer.json index 1440cc3..7f193da 100644 --- a/vendor/bacon/bacon-qr-code/composer.json +++ b/vendor/bacon/bacon-qr-code/composer.json @@ -34,5 +34,11 @@ "allow-plugins": { "ocramius/package-versions": true } + }, + "archive": { + "exclude": [ + "/test", + "/phpunit.xml.dist" + ] } } diff --git a/vendor/bacon/bacon-qr-code/phpunit.xml.dist b/vendor/bacon/bacon-qr-code/phpunit.xml.dist new file mode 100644 index 0000000..d9e4d57 --- /dev/null +++ b/vendor/bacon/bacon-qr-code/phpunit.xml.dist @@ -0,0 +1,13 @@ + + + + + src + + + + + ./test + + + diff --git a/vendor/bacon/bacon-qr-code/src/Common/CharacterSetEci.php b/vendor/bacon/bacon-qr-code/src/Common/CharacterSetEci.php index 6dfff17..9049ccb 100644 --- a/vendor/bacon/bacon-qr-code/src/Common/CharacterSetEci.php +++ b/vendor/bacon/bacon-qr-code/src/Common/CharacterSetEci.php @@ -89,6 +89,9 @@ final class CharacterSetEci extends AbstractEnum */ private static $nameToEci; + /** + * @param int[] $values + */ public function __construct(array $values, string ...$otherEncodingNames) { $this->values = $values; diff --git a/vendor/bacon/bacon-qr-code/src/Common/FormatInformation.php b/vendor/bacon/bacon-qr-code/src/Common/FormatInformation.php index 53e3541..38295fc 100644 --- a/vendor/bacon/bacon-qr-code/src/Common/FormatInformation.php +++ b/vendor/bacon/bacon-qr-code/src/Common/FormatInformation.php @@ -62,7 +62,7 @@ class FormatInformation /** * Offset i holds the number of 1 bits in the binary representation of i. * - * @var array + * @var int[] */ private const BITS_SET_IN_HALF_BYTE = [0, 1, 1, 2, 1, 2, 2, 3, 1, 2, 2, 3, 2, 3, 3, 4]; diff --git a/vendor/bacon/bacon-qr-code/src/Common/Mode.php b/vendor/bacon/bacon-qr-code/src/Common/Mode.php index 51e6c9a..af5a113 100644 --- a/vendor/bacon/bacon-qr-code/src/Common/Mode.php +++ b/vendor/bacon/bacon-qr-code/src/Common/Mode.php @@ -42,6 +42,9 @@ final class Mode extends AbstractEnum */ private $bits; + /** + * @param int[] $characterCountBitsForVersions + */ protected function __construct(array $characterCountBitsForVersions, int $bits) { $this->characterCountBitsForVersions = $characterCountBitsForVersions; diff --git a/vendor/bacon/bacon-qr-code/src/Encoder/Encoder.php b/vendor/bacon/bacon-qr-code/src/Encoder/Encoder.php index cf4fde0..3208460 100644 --- a/vendor/bacon/bacon-qr-code/src/Encoder/Encoder.php +++ b/vendor/bacon/bacon-qr-code/src/Encoder/Encoder.php @@ -37,7 +37,7 @@ final class Encoder /** * Codec cache. * - * @var array + * @var array */ private static $codecs = []; diff --git a/vendor/bacon/bacon-qr-code/src/Renderer/Image/SvgImageBackEnd.php b/vendor/bacon/bacon-qr-code/src/Renderer/Image/SvgImageBackEnd.php index 714da6e..cb37a9f 100644 --- a/vendor/bacon/bacon-qr-code/src/Renderer/Image/SvgImageBackEnd.php +++ b/vendor/bacon/bacon-qr-code/src/Renderer/Image/SvgImageBackEnd.php @@ -334,7 +334,7 @@ final class SvgImageBackEnd implements ImageBackEndInterface $this->xmlWriter->writeAttribute('stop-color', $this->getColorString($startColor)); if ($startColor instanceof Alpha) { - $this->xmlWriter->writeAttribute('stop-opacity', $startColor->getAlpha()); + $this->xmlWriter->writeAttribute('stop-opacity', (string) $startColor->getAlpha()); } $this->xmlWriter->endElement(); @@ -344,7 +344,7 @@ final class SvgImageBackEnd implements ImageBackEndInterface $this->xmlWriter->writeAttribute('stop-color', $this->getColorString($endColor)); if ($endColor instanceof Alpha) { - $this->xmlWriter->writeAttribute('stop-opacity', $endColor->getAlpha()); + $this->xmlWriter->writeAttribute('stop-opacity', (string) $endColor->getAlpha()); } $this->xmlWriter->endElement(); diff --git a/vendor/bacon/bacon-qr-code/src/Renderer/Module/EdgeIterator/EdgeIterator.php b/vendor/bacon/bacon-qr-code/src/Renderer/Module/EdgeIterator/EdgeIterator.php index af52d52..eb29dc6 100644 --- a/vendor/bacon/bacon-qr-code/src/Renderer/Module/EdgeIterator/EdgeIterator.php +++ b/vendor/bacon/bacon-qr-code/src/Renderer/Module/EdgeIterator/EdgeIterator.php @@ -41,7 +41,7 @@ final class EdgeIterator implements IteratorAggregate } /** - * @return Edge[] + * @return Traversable */ public function getIterator() : Traversable { diff --git a/vendor/bacon/bacon-qr-code/src/Renderer/Path/EllipticArc.php b/vendor/bacon/bacon-qr-code/src/Renderer/Path/EllipticArc.php index eff7deb..9f2385a 100644 --- a/vendor/bacon/bacon-qr-code/src/Renderer/Path/EllipticArc.php +++ b/vendor/bacon/bacon-qr-code/src/Renderer/Path/EllipticArc.php @@ -136,7 +136,7 @@ final class EllipticArc implements OperationInterface /** * @return Curve[] */ - private function createCurves(float $fromX, $fromY) : array + private function createCurves(float $fromX, float $fromY) : array { $xAngle = deg2rad($this->xAxisAngle); list($centerX, $centerY, $radiusX, $radiusY, $startAngle, $deltaAngle) = diff --git a/vendor/bacon/bacon-qr-code/test/Integration/ImagickRenderingTest.php b/vendor/bacon/bacon-qr-code/test/Integration/ImagickRenderingTest.php index 39e44bf..3df8687 100644 --- a/vendor/bacon/bacon-qr-code/test/Integration/ImagickRenderingTest.php +++ b/vendor/bacon/bacon-qr-code/test/Integration/ImagickRenderingTest.php @@ -17,10 +17,16 @@ use BaconQrCode\Writer; use PHPUnit\Framework\TestCase; use Spatie\Snapshots\MatchesSnapshots; +/** + * @group integration + */ final class ImagickRenderingTest extends TestCase { use MatchesSnapshots; + /** + * @requires extension imagick + */ public function testGenericQrCode() : void { $renderer = new ImageRenderer( @@ -35,6 +41,9 @@ final class ImagickRenderingTest extends TestCase unlink($tempName); } + /** + * @requires extension imagick + */ public function testIssue79() : void { $eye = SquareEye::instance(); diff --git a/vendor/bin/lessc b/vendor/bin/lessc index 7ae7f57..d2c6c96 100644 --- a/vendor/bin/lessc +++ b/vendor/bin/lessc @@ -108,10 +108,12 @@ if (PHP_VERSION_ID < 80000) { } } - if (function_exists('stream_wrapper_register') && stream_wrapper_register('phpvfscomposer', 'Composer\BinProxyWrapper')) { - include("phpvfscomposer://" . __DIR__ . '/..'.'/wikimedia/less.php/bin/lessc'); - exit(0); + if ( + (function_exists('stream_get_wrappers') && in_array('phpvfscomposer', stream_get_wrappers(), true)) + || (function_exists('stream_wrapper_register') && stream_wrapper_register('phpvfscomposer', 'Composer\BinProxyWrapper')) + ) { + return include("phpvfscomposer://" . __DIR__ . '/..'.'/wikimedia/less.php/bin/lessc'); } } -include __DIR__ . '/..'.'/wikimedia/less.php/bin/lessc'; +return include __DIR__ . '/..'.'/wikimedia/less.php/bin/lessc'; diff --git a/vendor/composer/ClassLoader.php b/vendor/composer/ClassLoader.php index afef3fa..7824d8f 100644 --- a/vendor/composer/ClassLoader.php +++ b/vendor/composer/ClassLoader.php @@ -42,35 +42,37 @@ namespace Composer\Autoload; */ class ClassLoader { - /** @var ?string */ + /** @var \Closure(string):void */ + private static $includeFile; + + /** @var string|null */ private $vendorDir; // PSR-4 /** - * @var array[] - * @psalm-var array> + * @var array> */ private $prefixLengthsPsr4 = array(); /** - * @var array[] - * @psalm-var array> + * @var array> */ private $prefixDirsPsr4 = array(); /** - * @var array[] - * @psalm-var array + * @var list */ private $fallbackDirsPsr4 = array(); // PSR-0 /** - * @var array[] - * @psalm-var array> + * List of PSR-0 prefixes + * + * Structured as array('F (first letter)' => array('Foo\Bar (full prefix)' => array('path', 'path2'))) + * + * @var array>> */ private $prefixesPsr0 = array(); /** - * @var array[] - * @psalm-var array + * @var list */ private $fallbackDirsPsr0 = array(); @@ -78,8 +80,7 @@ class ClassLoader private $useIncludePath = false; /** - * @var string[] - * @psalm-var array + * @var array */ private $classMap = array(); @@ -87,29 +88,29 @@ class ClassLoader private $classMapAuthoritative = false; /** - * @var bool[] - * @psalm-var array + * @var array */ private $missingClasses = array(); - /** @var ?string */ + /** @var string|null */ private $apcuPrefix; /** - * @var self[] + * @var array */ private static $registeredLoaders = array(); /** - * @param ?string $vendorDir + * @param string|null $vendorDir */ public function __construct($vendorDir = null) { $this->vendorDir = $vendorDir; + self::initializeIncludeClosure(); } /** - * @return string[] + * @return array> */ public function getPrefixes() { @@ -121,8 +122,7 @@ class ClassLoader } /** - * @return array[] - * @psalm-return array> + * @return array> */ public function getPrefixesPsr4() { @@ -130,8 +130,7 @@ class ClassLoader } /** - * @return array[] - * @psalm-return array + * @return list */ public function getFallbackDirs() { @@ -139,8 +138,7 @@ class ClassLoader } /** - * @return array[] - * @psalm-return array + * @return list */ public function getFallbackDirsPsr4() { @@ -148,8 +146,7 @@ class ClassLoader } /** - * @return string[] Array of classname => path - * @psalm-return array + * @return array Array of classname => path */ public function getClassMap() { @@ -157,8 +154,7 @@ class ClassLoader } /** - * @param string[] $classMap Class to filename map - * @psalm-param array $classMap + * @param array $classMap Class to filename map * * @return void */ @@ -175,24 +171,25 @@ class ClassLoader * Registers a set of PSR-0 directories for a given prefix, either * appending or prepending to the ones previously set for this prefix. * - * @param string $prefix The prefix - * @param string[]|string $paths The PSR-0 root directories - * @param bool $prepend Whether to prepend the directories + * @param string $prefix The prefix + * @param list|string $paths The PSR-0 root directories + * @param bool $prepend Whether to prepend the directories * * @return void */ public function add($prefix, $paths, $prepend = false) { + $paths = (array) $paths; if (!$prefix) { if ($prepend) { $this->fallbackDirsPsr0 = array_merge( - (array) $paths, + $paths, $this->fallbackDirsPsr0 ); } else { $this->fallbackDirsPsr0 = array_merge( $this->fallbackDirsPsr0, - (array) $paths + $paths ); } @@ -201,19 +198,19 @@ class ClassLoader $first = $prefix[0]; if (!isset($this->prefixesPsr0[$first][$prefix])) { - $this->prefixesPsr0[$first][$prefix] = (array) $paths; + $this->prefixesPsr0[$first][$prefix] = $paths; return; } if ($prepend) { $this->prefixesPsr0[$first][$prefix] = array_merge( - (array) $paths, + $paths, $this->prefixesPsr0[$first][$prefix] ); } else { $this->prefixesPsr0[$first][$prefix] = array_merge( $this->prefixesPsr0[$first][$prefix], - (array) $paths + $paths ); } } @@ -222,9 +219,9 @@ class ClassLoader * Registers a set of PSR-4 directories for a given namespace, either * appending or prepending to the ones previously set for this namespace. * - * @param string $prefix The prefix/namespace, with trailing '\\' - * @param string[]|string $paths The PSR-4 base directories - * @param bool $prepend Whether to prepend the directories + * @param string $prefix The prefix/namespace, with trailing '\\' + * @param list|string $paths The PSR-4 base directories + * @param bool $prepend Whether to prepend the directories * * @throws \InvalidArgumentException * @@ -232,17 +229,18 @@ class ClassLoader */ public function addPsr4($prefix, $paths, $prepend = false) { + $paths = (array) $paths; if (!$prefix) { // Register directories for the root namespace. if ($prepend) { $this->fallbackDirsPsr4 = array_merge( - (array) $paths, + $paths, $this->fallbackDirsPsr4 ); } else { $this->fallbackDirsPsr4 = array_merge( $this->fallbackDirsPsr4, - (array) $paths + $paths ); } } elseif (!isset($this->prefixDirsPsr4[$prefix])) { @@ -252,18 +250,18 @@ class ClassLoader throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator."); } $this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length; - $this->prefixDirsPsr4[$prefix] = (array) $paths; + $this->prefixDirsPsr4[$prefix] = $paths; } elseif ($prepend) { // Prepend directories for an already registered namespace. $this->prefixDirsPsr4[$prefix] = array_merge( - (array) $paths, + $paths, $this->prefixDirsPsr4[$prefix] ); } else { // Append directories for an already registered namespace. $this->prefixDirsPsr4[$prefix] = array_merge( $this->prefixDirsPsr4[$prefix], - (array) $paths + $paths ); } } @@ -272,8 +270,8 @@ class ClassLoader * Registers a set of PSR-0 directories for a given prefix, * replacing any others previously set for this prefix. * - * @param string $prefix The prefix - * @param string[]|string $paths The PSR-0 base directories + * @param string $prefix The prefix + * @param list|string $paths The PSR-0 base directories * * @return void */ @@ -290,8 +288,8 @@ class ClassLoader * Registers a set of PSR-4 directories for a given namespace, * replacing any others previously set for this namespace. * - * @param string $prefix The prefix/namespace, with trailing '\\' - * @param string[]|string $paths The PSR-4 base directories + * @param string $prefix The prefix/namespace, with trailing '\\' + * @param list|string $paths The PSR-4 base directories * * @throws \InvalidArgumentException * @@ -425,7 +423,8 @@ class ClassLoader public function loadClass($class) { if ($file = $this->findFile($class)) { - includeFile($file); + $includeFile = self::$includeFile; + $includeFile($file); return true; } @@ -476,9 +475,9 @@ class ClassLoader } /** - * Returns the currently registered loaders indexed by their corresponding vendor directories. + * Returns the currently registered loaders keyed by their corresponding vendor directories. * - * @return self[] + * @return array */ public static function getRegisteredLoaders() { @@ -555,18 +554,26 @@ class ClassLoader return false; } -} -/** - * Scope isolated include. - * - * Prevents access to $this/self from included files. - * - * @param string $file - * @return void - * @private - */ -function includeFile($file) -{ - include $file; + /** + * @return void + */ + private static function initializeIncludeClosure() + { + if (self::$includeFile !== null) { + return; + } + + /** + * Scope isolated include. + * + * Prevents access to $this/self from included files. + * + * @param string $file + * @return void + */ + self::$includeFile = \Closure::bind(static function($file) { + include $file; + }, null, null); + } } diff --git a/vendor/composer/InstalledVersions.php b/vendor/composer/InstalledVersions.php index c6b54af..51e734a 100644 --- a/vendor/composer/InstalledVersions.php +++ b/vendor/composer/InstalledVersions.php @@ -98,7 +98,7 @@ class InstalledVersions { foreach (self::getInstalled() as $installed) { if (isset($installed['versions'][$packageName])) { - return $includeDevRequirements || empty($installed['versions'][$packageName]['dev_requirement']); + return $includeDevRequirements || !isset($installed['versions'][$packageName]['dev_requirement']) || $installed['versions'][$packageName]['dev_requirement'] === false; } } @@ -119,7 +119,7 @@ class InstalledVersions */ public static function satisfies(VersionParser $parser, $packageName, $constraint) { - $constraint = $parser->parseConstraints($constraint); + $constraint = $parser->parseConstraints((string) $constraint); $provided = $parser->parseConstraints(self::getVersionRanges($packageName)); return $provided->matches($constraint); @@ -328,7 +328,9 @@ class InstalledVersions if (isset(self::$installedByVendor[$vendorDir])) { $installed[] = self::$installedByVendor[$vendorDir]; } elseif (is_file($vendorDir.'/composer/installed.php')) { - $installed[] = self::$installedByVendor[$vendorDir] = require $vendorDir.'/composer/installed.php'; + /** @var array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array} $required */ + $required = require $vendorDir.'/composer/installed.php'; + $installed[] = self::$installedByVendor[$vendorDir] = $required; if (null === self::$installed && strtr($vendorDir.'/composer', '\\', '/') === strtr(__DIR__, '\\', '/')) { self::$installed = $installed[count($installed) - 1]; } @@ -340,12 +342,17 @@ class InstalledVersions // only require the installed.php file if this file is loaded from its dumped location, // and not from its source location in the composer/composer package, see https://github.com/composer/composer/issues/9937 if (substr(__DIR__, -8, 1) !== 'C') { - self::$installed = require __DIR__ . '/installed.php'; + /** @var array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array} $required */ + $required = require __DIR__ . '/installed.php'; + self::$installed = $required; } else { self::$installed = array(); } } - $installed[] = self::$installed; + + if (self::$installed !== array()) { + $installed[] = self::$installed; + } return $installed; } diff --git a/vendor/composer/autoload_real.php b/vendor/composer/autoload_real.php index a81e37d..a767034 100644 --- a/vendor/composer/autoload_real.php +++ b/vendor/composer/autoload_real.php @@ -2,7 +2,7 @@ // autoload_real.php @generated by Composer -class ComposerAutoloaderInit6bb82695b2f28e8ee61f74ae2d5c5202 +class ComposerAutoloaderInitd4957e04ba4dff37d0ecbf0a4b59e14a { private static $loader; @@ -24,12 +24,12 @@ class ComposerAutoloaderInit6bb82695b2f28e8ee61f74ae2d5c5202 require __DIR__ . '/platform_check.php'; - spl_autoload_register(array('ComposerAutoloaderInit6bb82695b2f28e8ee61f74ae2d5c5202', 'loadClassLoader'), true, true); + spl_autoload_register(array('ComposerAutoloaderInitd4957e04ba4dff37d0ecbf0a4b59e14a', 'loadClassLoader'), true, true); self::$loader = $loader = new \Composer\Autoload\ClassLoader(\dirname(__DIR__)); - spl_autoload_unregister(array('ComposerAutoloaderInit6bb82695b2f28e8ee61f74ae2d5c5202', 'loadClassLoader')); + spl_autoload_unregister(array('ComposerAutoloaderInitd4957e04ba4dff37d0ecbf0a4b59e14a', 'loadClassLoader')); require __DIR__ . '/autoload_static.php'; - call_user_func(\Composer\Autoload\ComposerStaticInit6bb82695b2f28e8ee61f74ae2d5c5202::getInitializer($loader)); + call_user_func(\Composer\Autoload\ComposerStaticInitd4957e04ba4dff37d0ecbf0a4b59e14a::getInitializer($loader)); $loader->register(true); diff --git a/vendor/composer/autoload_static.php b/vendor/composer/autoload_static.php index c6b0153..b2e269c 100644 --- a/vendor/composer/autoload_static.php +++ b/vendor/composer/autoload_static.php @@ -4,7 +4,7 @@ namespace Composer\Autoload; -class ComposerStaticInit6bb82695b2f28e8ee61f74ae2d5c5202 +class ComposerStaticInitd4957e04ba4dff37d0ecbf0a4b59e14a { public static $prefixLengthsPsr4 = array ( 'E' => @@ -54,10 +54,10 @@ class ComposerStaticInit6bb82695b2f28e8ee61f74ae2d5c5202 public static function getInitializer(ClassLoader $loader) { return \Closure::bind(function () use ($loader) { - $loader->prefixLengthsPsr4 = ComposerStaticInit6bb82695b2f28e8ee61f74ae2d5c5202::$prefixLengthsPsr4; - $loader->prefixDirsPsr4 = ComposerStaticInit6bb82695b2f28e8ee61f74ae2d5c5202::$prefixDirsPsr4; - $loader->prefixesPsr0 = ComposerStaticInit6bb82695b2f28e8ee61f74ae2d5c5202::$prefixesPsr0; - $loader->classMap = ComposerStaticInit6bb82695b2f28e8ee61f74ae2d5c5202::$classMap; + $loader->prefixLengthsPsr4 = ComposerStaticInitd4957e04ba4dff37d0ecbf0a4b59e14a::$prefixLengthsPsr4; + $loader->prefixDirsPsr4 = ComposerStaticInitd4957e04ba4dff37d0ecbf0a4b59e14a::$prefixDirsPsr4; + $loader->prefixesPsr0 = ComposerStaticInitd4957e04ba4dff37d0ecbf0a4b59e14a::$prefixesPsr0; + $loader->classMap = ComposerStaticInitd4957e04ba4dff37d0ecbf0a4b59e14a::$classMap; }, null, ClassLoader::class); } diff --git a/vendor/composer/installed.json b/vendor/composer/installed.json index d43d4f1..dec70d7 100644 --- a/vendor/composer/installed.json +++ b/vendor/composer/installed.json @@ -2,17 +2,17 @@ "packages": [ { "name": "bacon/bacon-qr-code", - "version": "2.0.7", - "version_normalized": "2.0.7.0", + "version": "2.0.8", + "version_normalized": "2.0.8.0", "source": { "type": "git", "url": "https://github.com/Bacon/BaconQrCode.git", - "reference": "d70c840f68657ce49094b8d91f9ee0cc07fbf66c" + "reference": "8674e51bb65af933a5ffaf1c308a660387c35c22" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/Bacon/BaconQrCode/zipball/d70c840f68657ce49094b8d91f9ee0cc07fbf66c", - "reference": "d70c840f68657ce49094b8d91f9ee0cc07fbf66c", + "url": "https://api.github.com/repos/Bacon/BaconQrCode/zipball/8674e51bb65af933a5ffaf1c308a660387c35c22", + "reference": "8674e51bb65af933a5ffaf1c308a660387c35c22", "shasum": "" }, "require": { @@ -29,7 +29,7 @@ "suggest": { "ext-imagick": "to generate QR code images" }, - "time": "2022-03-14T02:02:36+00:00", + "time": "2022-12-07T17:46:57+00:00", "type": "library", "installation-source": "dist", "autoload": { @@ -53,30 +53,33 @@ "homepage": "https://github.com/Bacon/BaconQrCode", "support": { "issues": "https://github.com/Bacon/BaconQrCode/issues", - "source": "https://github.com/Bacon/BaconQrCode/tree/2.0.7" + "source": "https://github.com/Bacon/BaconQrCode/tree/2.0.8" }, "install-path": "../bacon/bacon-qr-code" }, { "name": "dasprid/enum", - "version": "1.0.3", - "version_normalized": "1.0.3.0", + "version": "1.0.4", + "version_normalized": "1.0.4.0", "source": { "type": "git", "url": "https://github.com/DASPRiD/Enum.git", - "reference": "5abf82f213618696dda8e3bf6f64dd042d8542b2" + "reference": "8e6b6ea76eabbf19ea2bf5b67b98e1860474012f" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/DASPRiD/Enum/zipball/5abf82f213618696dda8e3bf6f64dd042d8542b2", - "reference": "5abf82f213618696dda8e3bf6f64dd042d8542b2", + "url": "https://api.github.com/repos/DASPRiD/Enum/zipball/8e6b6ea76eabbf19ea2bf5b67b98e1860474012f", + "reference": "8e6b6ea76eabbf19ea2bf5b67b98e1860474012f", "shasum": "" }, + "require": { + "php": ">=7.1 <9.0" + }, "require-dev": { "phpunit/phpunit": "^7 | ^8 | ^9", - "squizlabs/php_codesniffer": "^3.4" + "squizlabs/php_codesniffer": "*" }, - "time": "2020-10-02T16:03:48+00:00", + "time": "2023-03-01T18:44:03+00:00", "type": "library", "installation-source": "dist", "autoload": { @@ -103,33 +106,36 @@ ], "support": { "issues": "https://github.com/DASPRiD/Enum/issues", - "source": "https://github.com/DASPRiD/Enum/tree/1.0.3" + "source": "https://github.com/DASPRiD/Enum/tree/1.0.4" }, "install-path": "../dasprid/enum" }, { "name": "endroid/qr-code", - "version": "4.4.9", - "version_normalized": "4.4.9.0", + "version": "4.8.2", + "version_normalized": "4.8.2.0", "source": { "type": "git", "url": "https://github.com/endroid/qr-code.git", - "reference": "bf087fa1e93a1b7310e2d94d187e26ae51db199d" + "reference": "2436c2333a3931c95e2b96eb82f16f53143d6bba" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/endroid/qr-code/zipball/bf087fa1e93a1b7310e2d94d187e26ae51db199d", - "reference": "bf087fa1e93a1b7310e2d94d187e26ae51db199d", + "url": "https://api.github.com/repos/endroid/qr-code/zipball/2436c2333a3931c95e2b96eb82f16f53143d6bba", + "reference": "2436c2333a3931c95e2b96eb82f16f53143d6bba", "shasum": "" }, "require": { "bacon/bacon-qr-code": "^2.0.5", - "php": "^7.4||^8.0" + "php": "^8.0" + }, + "conflict": { + "khanamiryan/qrcode-detector-decoder": "^1.0.6" }, "require-dev": { "endroid/quality": "dev-master", "ext-gd": "*", - "khanamiryan/qrcode-detector-decoder": "^1.0.4", + "khanamiryan/qrcode-detector-decoder": "^1.0.4||^2.0.2", "setasign/fpdf": "^1.8.2" }, "suggest": { @@ -138,7 +144,7 @@ "roave/security-advisories": "Makes sure package versions with known security issues are not installed", "setasign/fpdf": "Enables you to use the PDF writer" }, - "time": "2022-05-10T07:25:08+00:00", + "time": "2023-03-30T18:46:02+00:00", "type": "library", "extra": { "branch-alias": { @@ -172,7 +178,7 @@ ], "support": { "issues": "https://github.com/endroid/qr-code/issues", - "source": "https://github.com/endroid/qr-code/tree/4.4.9" + "source": "https://github.com/endroid/qr-code/tree/4.8.2" }, "funding": [ { @@ -184,30 +190,31 @@ }, { "name": "wikimedia/less.php", - "version": "v3.1.0", - "version_normalized": "3.1.0.0", + "version": "v3.2.1", + "version_normalized": "3.2.1.0", "source": { "type": "git", "url": "https://github.com/wikimedia/less.php.git", - "reference": "a486d78b9bd16b72f237fc6093aa56d69ce8bd13" + "reference": "0d5b30ba792bdbf8991a646fc9c30561b38a5559" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/wikimedia/less.php/zipball/a486d78b9bd16b72f237fc6093aa56d69ce8bd13", - "reference": "a486d78b9bd16b72f237fc6093aa56d69ce8bd13", + "url": "https://api.github.com/repos/wikimedia/less.php/zipball/0d5b30ba792bdbf8991a646fc9c30561b38a5559", + "reference": "0d5b30ba792bdbf8991a646fc9c30561b38a5559", "shasum": "" }, "require": { "php": ">=7.2.9" }, "require-dev": { - "mediawiki/mediawiki-codesniffer": "34.0.0", - "mediawiki/minus-x": "1.0.0", - "php-parallel-lint/php-console-highlighter": "0.5.0", - "php-parallel-lint/php-parallel-lint": "1.2.0", + "mediawiki/mediawiki-codesniffer": "40.0.1", + "mediawiki/mediawiki-phan-config": "0.12.0", + "mediawiki/minus-x": "1.1.1", + "php-parallel-lint/php-console-highlighter": "1.0.0", + "php-parallel-lint/php-parallel-lint": "1.3.2", "phpunit/phpunit": "^8.5" }, - "time": "2020-12-11T19:33:31+00:00", + "time": "2023-02-03T06:43:41+00:00", "bin": [ "bin/lessc" ], @@ -226,6 +233,10 @@ "Apache-2.0" ], "authors": [ + { + "name": "Timo Tijhof", + "homepage": "https://timotijhof.net" + }, { "name": "Josh Schmidt", "homepage": "https://github.com/oyejorge" @@ -239,7 +250,8 @@ "homepage": "https://github.com/Mordred" } ], - "description": "PHP port of the Javascript version of LESS http://lesscss.org (Originally maintained by Josh Schmidt)", + "description": "PHP port of the LESS processor", + "homepage": "https://gerrit.wikimedia.org/g/mediawiki/libs/less.php", "keywords": [ "css", "less", @@ -250,7 +262,7 @@ ], "support": { "issues": "https://github.com/wikimedia/less.php/issues", - "source": "https://github.com/wikimedia/less.php/tree/v3.1.0" + "source": "https://github.com/wikimedia/less.php/tree/v3.2.1" }, "install-path": "../wikimedia/less.php" } diff --git a/vendor/composer/installed.php b/vendor/composer/installed.php index 7c8fcd4..2c32d24 100644 --- a/vendor/composer/installed.php +++ b/vendor/composer/installed.php @@ -3,7 +3,7 @@ 'name' => '__root__', 'pretty_version' => 'dev-main', 'version' => 'dev-main', - 'reference' => '5e455c1499d4fba2d9bb825e4db8b58a3a6a595e', + 'reference' => 'b4ef98673f4ec96aac0c1ff7bda444f72101c479', 'type' => 'library', 'install_path' => __DIR__ . '/../../', 'aliases' => array(), @@ -13,43 +13,43 @@ '__root__' => array( 'pretty_version' => 'dev-main', 'version' => 'dev-main', - 'reference' => '5e455c1499d4fba2d9bb825e4db8b58a3a6a595e', + 'reference' => 'b4ef98673f4ec96aac0c1ff7bda444f72101c479', 'type' => 'library', 'install_path' => __DIR__ . '/../../', 'aliases' => array(), 'dev_requirement' => false, ), 'bacon/bacon-qr-code' => array( - 'pretty_version' => '2.0.7', - 'version' => '2.0.7.0', - 'reference' => 'd70c840f68657ce49094b8d91f9ee0cc07fbf66c', + 'pretty_version' => '2.0.8', + 'version' => '2.0.8.0', + 'reference' => '8674e51bb65af933a5ffaf1c308a660387c35c22', 'type' => 'library', 'install_path' => __DIR__ . '/../bacon/bacon-qr-code', 'aliases' => array(), 'dev_requirement' => false, ), 'dasprid/enum' => array( - 'pretty_version' => '1.0.3', - 'version' => '1.0.3.0', - 'reference' => '5abf82f213618696dda8e3bf6f64dd042d8542b2', + 'pretty_version' => '1.0.4', + 'version' => '1.0.4.0', + 'reference' => '8e6b6ea76eabbf19ea2bf5b67b98e1860474012f', 'type' => 'library', 'install_path' => __DIR__ . '/../dasprid/enum', 'aliases' => array(), 'dev_requirement' => false, ), 'endroid/qr-code' => array( - 'pretty_version' => '4.4.9', - 'version' => '4.4.9.0', - 'reference' => 'bf087fa1e93a1b7310e2d94d187e26ae51db199d', + 'pretty_version' => '4.8.2', + 'version' => '4.8.2.0', + 'reference' => '2436c2333a3931c95e2b96eb82f16f53143d6bba', 'type' => 'library', 'install_path' => __DIR__ . '/../endroid/qr-code', 'aliases' => array(), 'dev_requirement' => false, ), 'wikimedia/less.php' => array( - 'pretty_version' => 'v3.1.0', - 'version' => '3.1.0.0', - 'reference' => 'a486d78b9bd16b72f237fc6093aa56d69ce8bd13', + 'pretty_version' => 'v3.2.1', + 'version' => '3.2.1.0', + 'reference' => '0d5b30ba792bdbf8991a646fc9c30561b38a5559', 'type' => 'library', 'install_path' => __DIR__ . '/../wikimedia/less.php', 'aliases' => array(), diff --git a/vendor/composer/platform_check.php b/vendor/composer/platform_check.php index 580fa96..adfb472 100644 --- a/vendor/composer/platform_check.php +++ b/vendor/composer/platform_check.php @@ -4,8 +4,8 @@ $issues = array(); -if (!(PHP_VERSION_ID >= 70400)) { - $issues[] = 'Your Composer dependencies require a PHP version ">= 7.4.0". You are running ' . PHP_VERSION . '.'; +if (!(PHP_VERSION_ID >= 80000)) { + $issues[] = 'Your Composer dependencies require a PHP version ">= 8.0.0". You are running ' . PHP_VERSION . '.'; } if ($issues) { diff --git a/vendor/dasprid/enum/.github/workflows/tests.yml b/vendor/dasprid/enum/.github/workflows/tests.yml new file mode 100644 index 0000000..94b2562 --- /dev/null +++ b/vendor/dasprid/enum/.github/workflows/tests.yml @@ -0,0 +1,47 @@ +name: Tests + +on: [push, pull_request] + +jobs: + php-tests: + runs-on: ${{ matrix.os }} + strategy: + fail-fast: true + matrix: + php: [8.2, 8.1, 8.0, 7.4, 7.3, 7.2, 7.1] + dependency-version: [prefer-stable] + os: [ubuntu-latest, windows-latest] + + name: ${{ matrix.os }} - PHP${{ matrix.php }} - ${{ matrix.dependency-version }} + + steps: + - name: Set git to use LF + run: | + git config --global core.autocrlf false + git config --global core.eol lf + + - name: Checkout code + uses: actions/checkout@v3 + + - name: Cache dependencies + uses: actions/cache@v3 + with: + path: ~/.composer/cache/files + key: dependencies-php-${{ matrix.php }}-composer-${{ hashFiles('composer.json') }} + + - name: Setup PHP + uses: shivammathur/setup-php@v2 + with: + php-version: ${{ matrix.php }} + coverage: none + + - name: Install dependencies + run: | + composer update --${{ matrix.dependency-version }} --prefer-dist --no-interaction + + - name: Execute tests + run: vendor/bin/phpunit + + - name: Code Sniffer + run: vendor/bin/phpcs + diff --git a/vendor/dasprid/enum/README.md b/vendor/dasprid/enum/README.md index 9e9ca12..da37045 100644 --- a/vendor/dasprid/enum/README.md +++ b/vendor/dasprid/enum/README.md @@ -1,6 +1,6 @@ # PHP 7.1 enums -[![Build Status](https://travis-ci.org/DASPRiD/Enum.svg?branch=master)](https://travis-ci.org/DASPRiD/Enum) +[![Build Status](https://github.com/DASPRiD/Enum/actions/workflows/tests.yml/badge.svg)](https://github.com/DASPRiD/Enum/actions?query=workflow%3Atests) [![Coverage Status](https://coveralls.io/repos/github/DASPRiD/Enum/badge.svg?branch=master)](https://coveralls.io/github/DASPRiD/Enum?branch=master) [![Latest Stable Version](https://poser.pugx.org/dasprid/enum/v/stable)](https://packagist.org/packages/dasprid/enum) [![Total Downloads](https://poser.pugx.org/dasprid/enum/downloads)](https://packagist.org/packages/dasprid/enum) @@ -41,7 +41,7 @@ final class WeekDay extends AbstractEnum protected const SATURDAY = null; protected const SUNDAY = null; } -``` +``` If you need to provide constants for either internal use or public use, you can mark them as either private or public, in which case they will be ignored by the enum, which only considers protected constants as valid values. As you can @@ -56,16 +56,16 @@ function tellItLikeItIs(WeekDay $weekDay) case WeekDay::MONDAY(): echo 'Mondays are bad.'; break; - + case WeekDay::FRIDAY(): echo 'Fridays are better.'; break; - + case WeekDay::SATURDAY(): case WeekDay::SUNDAY(): echo 'Weekends are best.'; break; - + default: echo 'Midweek days are so-so.'; } @@ -107,14 +107,14 @@ final class Planet extends AbstractEnum protected const SATURN = [5.688e+26, 6.0268e7]; protected const URANUS = [8.686e+25, 2.5559e7]; protected const NEPTUNE = [1.024e+26, 2.4746e7]; - + /** * Universal gravitational constant. * * @var float */ private const G = 6.67300E-11; - + /** * Mass in kilograms. * @@ -124,32 +124,32 @@ final class Planet extends AbstractEnum /** * Radius in meters. - * + * * @var float - */ + */ private $radius; - + protected function __construct(float $mass, float $radius) { $this->mass = $mass; $this->radius = $radius; } - + public function mass() : float { return $this->mass; } - + public function radius() : float { - return $this->radius; + return $this->radius; } - + public function surfaceGravity() : float { return self::G * $this->mass / ($this->radius * $this->radius); } - + public function surfaceWeight(float $otherMass) : float { return $otherMass * $this->surfaceGravity(); diff --git a/vendor/dasprid/enum/composer.json b/vendor/dasprid/enum/composer.json index b3d745a..133e279 100644 --- a/vendor/dasprid/enum/composer.json +++ b/vendor/dasprid/enum/composer.json @@ -14,9 +14,12 @@ "enum", "map" ], + "require": { + "php": ">=7.1 <9.0" + }, "require-dev": { "phpunit/phpunit": "^7 | ^8 | ^9", - "squizlabs/php_codesniffer": "^3.4" + "squizlabs/php_codesniffer": "*" }, "autoload": { "psr-4": { diff --git a/vendor/dasprid/enum/src/EnumMap.php b/vendor/dasprid/enum/src/EnumMap.php index 77c5f35..95b8856 100644 --- a/vendor/dasprid/enum/src/EnumMap.php +++ b/vendor/dasprid/enum/src/EnumMap.php @@ -88,6 +88,31 @@ final class EnumMap implements Serializable, IteratorAggregate $this->values = array_fill(0, count($this->keyUniverse), null); } + public function __serialize(): array + { + $values = []; + + foreach ($this->values as $ordinal => $value) { + if (null === $value) { + continue; + } + + $values[$ordinal] = $this->unmaskNull($value); + } + + return [ + 'keyType' => $this->keyType, + 'valueType' => $this->valueType, + 'allowNullValues' => $this->allowNullValues, + 'values' => $values, + ]; + } + + public function __unserialize(array $data): void + { + $this->unserialize(serialize($data)); + } + /** * Checks whether the map types match the supplied ones. * @@ -261,22 +286,7 @@ final class EnumMap implements Serializable, IteratorAggregate public function serialize() : string { - $values = []; - - foreach ($this->values as $ordinal => $value) { - if (null === $value) { - continue; - } - - $values[$ordinal] = $this->unmaskNull($value); - } - - return serialize([ - 'keyType' => $this->keyType, - 'valueType' => $this->valueType, - 'allowNullValues' => $this->allowNullValues, - 'values' => $values, - ]); + return serialize($this->__serialize()); } public function unserialize($serialized) : void diff --git a/vendor/endroid/qr-code/LICENSE b/vendor/endroid/qr-code/LICENSE index 6d36c02..546d814 100644 --- a/vendor/endroid/qr-code/LICENSE +++ b/vendor/endroid/qr-code/LICENSE @@ -1,4 +1,4 @@ -Copyright 2020 (c) Jeroen van den Enden +Copyright 2022 (c) Jeroen van den Enden Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal diff --git a/vendor/endroid/qr-code/README.md b/vendor/endroid/qr-code/README.md index 1d78681..35cbac3 100644 --- a/vendor/endroid/qr-code/README.md +++ b/vendor/endroid/qr-code/README.md @@ -14,13 +14,17 @@ for validating generated QR codes. Further extended with Twig extensions, genera Symfony bundle for easy installation and configuration. Different writers are provided to generate the QR code as PNG, SVG, EPS or in binary format. +## Sponsored by + +[![Blackfire.io](assets/blackfire.png)](https://www.blackfire.io) + ## Installation Use [Composer](https://getcomposer.org/) to install the library. Also make sure you have enabled and configured the [GD extension](https://www.php.net/manual/en/book.image.php) if you want to generate images. ``` bash -$ composer require endroid/qr-code + composer require endroid/qr-code ``` ## Usage: using the builder @@ -47,6 +51,7 @@ $result = Builder::create() ->labelText('This is the label') ->labelFont(new NotoSans(20)) ->labelAlignment(new LabelAlignmentCenter()) + ->validateResult(false) ->build(); ``` @@ -61,11 +66,12 @@ use Endroid\QrCode\Label\Label; use Endroid\QrCode\Logo\Logo; use Endroid\QrCode\RoundBlockSizeMode\RoundBlockSizeModeMargin; use Endroid\QrCode\Writer\PngWriter; +use Endroid\QrCode\Writer\ValidationException; $writer = new PngWriter(); // Create QR code -$qrCode = QrCode::create('Data') +$qrCode = QrCode::create('Life is too short to be generating QR codes') ->setEncoding(new Encoding('UTF-8')) ->setErrorCorrectionLevel(new ErrorCorrectionLevelLow()) ->setSize(300) @@ -83,6 +89,9 @@ $label = Label::create('Label') ->setTextColor(new Color(255, 0, 0)); $result = $writer->write($qrCode, $logo, $label); + +// Validate the result +$writer->validateResult($result, 'Life is too short to be generating QR codes'); ``` ## Usage: working with results @@ -104,10 +113,32 @@ $dataUri = $result->getDataUri(); ### Writer options +Some writers provide writer options. Each available writer option is can be +found as a constant prefixed with WRITER_OPTION_ in the writer class. + +* `PdfWriter` + * `unit`: unit of measurement (default: mm) + * `fpdf`: PDF to place the image in (default: new PDF) + * `x`: image offset (default: 0) + * `y`: image offset (default: 0) +* `PngWriter` + * `compression_level`: compression level (0-9, default: -1 = zlib default) +* `SvgWriter` + * `block_id`: id of the block element for external reference (default: block) + * `exclude_xml_declaration`: exclude XML declaration (default: false) + * `exclude_svg_width_and_height`: exclude width and height (default: false) + * `force_xlink_href`: forces xlink namespace in case of compatibility issues (default: false) +* `WebPWriter` + * `quality`: image quality (0-100, default: 80) + +You can provide any writer options like this. + ```php use Endroid\QrCode\Writer\SvgWriter; -$builder->setWriterOptions([SvgWriter::WRITER_OPTION_EXCLUDE_XML_DECLARATION => true]); +$builder->setWriterOptions([ + SvgWriter::WRITER_OPTION_EXCLUDE_XML_DECLARATION => true +]); ``` ### Encoding @@ -145,13 +176,14 @@ size can result in additional padding to compensate for the rounding difference. And finally the encoding (default UTF-8 to support large character sets) can be set to `ISO-8859-1` if possible to improve readability. -## Built-in validation reader +## Validating the generated QR code -You can enable the built-in validation reader (disabled by default) by calling -setValidateResult(true). This validation reader does not guarantee that the QR -code will be readable by all readers but it helps you provide a minimum level -of quality. Take note that the validator can consume quite amount of additional -resources and it should be installed separately only if you use it. +If you need to be extra sure the QR code you generated is readable and contains +the exact data you requested you can enable the validation reader, which is +disabled by default. You can do this either via the builder or directly on any +writer that supports validation. See the examples above. + +Please note that validation affects performance so only use it in case of problems. ## Symfony integration diff --git a/vendor/endroid/qr-code/assets/blackfire.png b/vendor/endroid/qr-code/assets/blackfire.png new file mode 100644 index 0000000000000000000000000000000000000000..bc378fd258f08fa96c7e346f531c1664437db2c8 GIT binary patch literal 28753 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