create-prisma-php-app 1.0.0 → 1.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +8 -0
- package/dist/index.js +1 -1
- package/dist/node_modules/prisma-client-php/index.js +1 -1
- package/package.json +11 -4
- package/vendor/brick/math/.editorconfig +0 -15
- package/vendor/brick/math/.gitattributes +0 -11
- package/vendor/brick/math/.github/FUNDING.yml +0 -1
- package/vendor/brick/math/.github/workflows/ci.yml +0 -80
- package/vendor/brick/math/CHANGELOG.md +0 -445
- package/vendor/brick/math/LICENSE +0 -20
- package/vendor/brick/math/README.md +0 -247
- package/vendor/brick/math/composer.json +0 -34
- package/vendor/brick/math/phpunit.php +0 -51
- package/vendor/brick/math/phpunit.xml +0 -13
- package/vendor/brick/math/psalm.xml +0 -28
- package/vendor/brick/math/random-tests.php +0 -162
- package/vendor/brick/math/src/BigDecimal.php +0 -786
- package/vendor/brick/math/src/BigInteger.php +0 -1079
- package/vendor/brick/math/src/BigNumber.php +0 -512
- package/vendor/brick/math/src/BigRational.php +0 -445
- package/vendor/brick/math/src/Exception/DivisionByZeroException.php +0 -35
- package/vendor/brick/math/src/Exception/IntegerOverflowException.php +0 -23
- package/vendor/brick/math/src/Exception/MathException.php +0 -12
- package/vendor/brick/math/src/Exception/NegativeNumberException.php +0 -12
- package/vendor/brick/math/src/Exception/NumberFormatException.php +0 -33
- package/vendor/brick/math/src/Exception/RoundingNecessaryException.php +0 -19
- package/vendor/brick/math/src/Internal/Calculator/BcMathCalculator.php +0 -75
- package/vendor/brick/math/src/Internal/Calculator/GmpCalculator.php +0 -108
- package/vendor/brick/math/src/Internal/Calculator/NativeCalculator.php +0 -581
- package/vendor/brick/math/src/Internal/Calculator.php +0 -676
- package/vendor/brick/math/src/RoundingMode.php +0 -107
- package/vendor/brick/math/tests/AbstractTestCase.php +0 -86
- package/vendor/brick/math/tests/BigDecimalTest.php +0 -2596
- package/vendor/brick/math/tests/BigIntegerTest.php +0 -3782
- package/vendor/brick/math/tests/BigNumberTest.php +0 -53
- package/vendor/brick/math/tests/BigRationalTest.php +0 -993
- package/vendor/brick/math/tests/CalculatorDetectTest.php +0 -25
- package/vendor/brick/math/tests/Internal/Calculator/NativeCalculatorTest.php +0 -87
- package/vendor/firebase/php-jwt/.gitattributes +0 -9
- package/vendor/firebase/php-jwt/.github/release-please.yml +0 -3
- package/vendor/firebase/php-jwt/.github/workflows/tests.yml +0 -57
- package/vendor/firebase/php-jwt/.php-cs-fixer.dist.php +0 -24
- package/vendor/firebase/php-jwt/CHANGELOG.md +0 -170
- package/vendor/firebase/php-jwt/LICENSE +0 -30
- package/vendor/firebase/php-jwt/README.md +0 -424
- package/vendor/firebase/php-jwt/composer.json +0 -42
- package/vendor/firebase/php-jwt/phpstan.neon.dist +0 -5
- package/vendor/firebase/php-jwt/phpunit.xml.dist +0 -18
- package/vendor/firebase/php-jwt/src/BeforeValidException.php +0 -18
- package/vendor/firebase/php-jwt/src/CachedKeySet.php +0 -268
- package/vendor/firebase/php-jwt/src/ExpiredException.php +0 -18
- package/vendor/firebase/php-jwt/src/JWK.php +0 -349
- package/vendor/firebase/php-jwt/src/JWT.php +0 -669
- package/vendor/firebase/php-jwt/src/JWTExceptionWithPayloadInterface.php +0 -20
- package/vendor/firebase/php-jwt/src/Key.php +0 -64
- package/vendor/firebase/php-jwt/src/SignatureInvalidException.php +0 -7
- package/vendor/firebase/php-jwt/tests/CachedKeySetTest.php +0 -598
- package/vendor/firebase/php-jwt/tests/JWKTest.php +0 -172
- package/vendor/firebase/php-jwt/tests/JWTTest.php +0 -543
- package/vendor/firebase/php-jwt/tests/data/ec-jwkset.json +0 -40
- package/vendor/firebase/php-jwt/tests/data/ecdsa-private.pem +0 -18
- package/vendor/firebase/php-jwt/tests/data/ecdsa-public.pem +0 -9
- package/vendor/firebase/php-jwt/tests/data/ecdsa256-private.pem +0 -4
- package/vendor/firebase/php-jwt/tests/data/ecdsa384-private.pem +0 -6
- package/vendor/firebase/php-jwt/tests/data/ecdsa384-public.pem +0 -5
- package/vendor/firebase/php-jwt/tests/data/ed25519-1.pub +0 -1
- package/vendor/firebase/php-jwt/tests/data/ed25519-1.sec +0 -1
- package/vendor/firebase/php-jwt/tests/data/ed25519-jwkset.json +0 -11
- package/vendor/firebase/php-jwt/tests/data/rsa-jwkset.json +0 -18
- package/vendor/firebase/php-jwt/tests/data/rsa-with-passphrase.pem +0 -42
- package/vendor/firebase/php-jwt/tests/data/rsa1-private.pem +0 -27
- package/vendor/firebase/php-jwt/tests/data/rsa1-public.pub +0 -9
- package/vendor/firebase/php-jwt/tests/data/rsa2-private.pem +0 -27
- package/vendor/firebase/php-jwt/tests/data/secp256k1-private.pem +0 -5
- package/vendor/firebase/php-jwt/tests/data/secp256k1-public.pem +0 -4
- package/vendor/graham-campbell/result-type/.gitattributes +0 -9
- package/vendor/graham-campbell/result-type/.github/CODE_OF_CONDUCT.md +0 -132
- package/vendor/graham-campbell/result-type/.github/CONTRIBUTING.md +0 -31
- package/vendor/graham-campbell/result-type/.github/FUNDING.yml +0 -2
- package/vendor/graham-campbell/result-type/.github/SECURITY.md +0 -14
- package/vendor/graham-campbell/result-type/.github/workflows/tests.yml +0 -40
- package/vendor/graham-campbell/result-type/CHANGELOG.md +0 -43
- package/vendor/graham-campbell/result-type/LICENSE +0 -21
- package/vendor/graham-campbell/result-type/README.md +0 -42
- package/vendor/graham-campbell/result-type/composer.json +0 -33
- package/vendor/graham-campbell/result-type/phpunit.xml.dist +0 -13
- package/vendor/graham-campbell/result-type/src/Error.php +0 -121
- package/vendor/graham-campbell/result-type/src/Result.php +0 -69
- package/vendor/graham-campbell/result-type/src/Success.php +0 -120
- package/vendor/graham-campbell/result-type/tests/ResultTest.php +0 -95
- package/vendor/hidehalo/nanoid-php/.editorconfig +0 -15
- package/vendor/hidehalo/nanoid-php/.gitattributes +0 -8
- package/vendor/hidehalo/nanoid-php/.github/workflows/php.yml +0 -49
- package/vendor/hidehalo/nanoid-php/.styleci.yml +0 -1
- package/vendor/hidehalo/nanoid-php/CHANGELOG.md +0 -36
- package/vendor/hidehalo/nanoid-php/CODE_OF_CONDUCT.md +0 -74
- package/vendor/hidehalo/nanoid-php/CONTRIBUTING.md +0 -32
- package/vendor/hidehalo/nanoid-php/ISSUE_TEMPLATE.md +0 -27
- package/vendor/hidehalo/nanoid-php/LICENSE.md +0 -21
- package/vendor/hidehalo/nanoid-php/PULL_REQUEST_TEMPLATE.md +0 -43
- package/vendor/hidehalo/nanoid-php/README.md +0 -108
- package/vendor/hidehalo/nanoid-php/benchmark/benchmark.php +0 -24
- package/vendor/hidehalo/nanoid-php/composer.json +0 -62
- package/vendor/hidehalo/nanoid-php/examples/basic_usage.php +0 -24
- package/vendor/hidehalo/nanoid-php/examples/custom_formated.php +0 -29
- package/vendor/hidehalo/nanoid-php/phpunit.xml +0 -31
- package/vendor/hidehalo/nanoid-php/src/Client.php +0 -120
- package/vendor/hidehalo/nanoid-php/src/Core.php +0 -31
- package/vendor/hidehalo/nanoid-php/src/CoreInterface.php +0 -19
- package/vendor/hidehalo/nanoid-php/src/Generator.php +0 -13
- package/vendor/hidehalo/nanoid-php/src/GeneratorInterface.php +0 -13
- package/vendor/hidehalo/nanoid-php/tests/ClientTest.php +0 -76
- package/vendor/hidehalo/nanoid-php/tests/CoreTest.php +0 -37
- package/vendor/hidehalo/nanoid-php/tests/GeneratorTest.php +0 -34
- package/vendor/hidehalo/nanoid-php/tests/Support/DummyGenerator.php +0 -20
- package/vendor/paragonie/random_compat/.gitattributes +0 -14
- package/vendor/paragonie/random_compat/.scrutinizer.yml +0 -4
- package/vendor/paragonie/random_compat/.travis.yml +0 -59
- package/vendor/paragonie/random_compat/CHANGELOG.md +0 -3
- package/vendor/paragonie/random_compat/LICENSE +0 -22
- package/vendor/paragonie/random_compat/RATIONALE.md +0 -36
- package/vendor/paragonie/random_compat/README.md +0 -232
- package/vendor/paragonie/random_compat/SECURITY.md +0 -108
- package/vendor/paragonie/random_compat/build-phar.sh +0 -5
- package/vendor/paragonie/random_compat/composer.json +0 -34
- package/vendor/paragonie/random_compat/dist/random_compat.phar.pubkey +0 -5
- package/vendor/paragonie/random_compat/dist/random_compat.phar.pubkey.asc +0 -11
- package/vendor/paragonie/random_compat/lib/random.php +0 -32
- package/vendor/paragonie/random_compat/other/build_phar.php +0 -57
- package/vendor/paragonie/random_compat/other/ide_stubs/COM.php +0 -20
- package/vendor/paragonie/random_compat/other/ide_stubs/README.md +0 -7
- package/vendor/paragonie/random_compat/other/ide_stubs/com_exception.php +0 -11
- package/vendor/paragonie/random_compat/other/ide_stubs/libsodium.php +0 -90
- package/vendor/paragonie/random_compat/phpunit.sh +0 -60
- package/vendor/paragonie/random_compat/phpunit.xml.dist +0 -31
- package/vendor/paragonie/random_compat/psalm-autoload.php +0 -9
- package/vendor/paragonie/random_compat/psalm.xml +0 -19
- package/vendor/paragonie/random_compat/tests/full/DieHardTest.php +0 -61
- package/vendor/paragonie/random_compat/tests/full/StatTest.php +0 -52
- package/vendor/paragonie/random_compat/tests/specific/capicom.php +0 -7
- package/vendor/paragonie/random_compat/tests/specific/dev_urandom.php +0 -7
- package/vendor/paragonie/random_compat/tests/specific/libsodium.php +0 -7
- package/vendor/paragonie/random_compat/tests/specific/libsodium_legacy.php +0 -7
- package/vendor/paragonie/random_compat/tests/specific/mcrypt.php +0 -7
- package/vendor/paragonie/random_compat/tests/unit/RandomBytesTest.php +0 -80
- package/vendor/paragonie/random_compat/tests/unit/RandomIntTest.php +0 -63
- package/vendor/paragonie/random_compat/tests/unit/UtilityTest.php +0 -95
- package/vendor/paragonie/random_compat/tests/unit_with_basedir/RandomBytesTest.php +0 -100
- package/vendor/paragonie/random_compat/tests/unit_with_basedir/RandomIntTest.php +0 -82
- package/vendor/paragonie/random_compat/tests/unit_with_basedir/UtilityTest.php +0 -95
- package/vendor/phpoption/phpoption/.gitattributes +0 -14
- package/vendor/phpoption/phpoption/.github/CODE_OF_CONDUCT.md +0 -132
- package/vendor/phpoption/phpoption/.github/CONTRIBUTING.md +0 -30
- package/vendor/phpoption/phpoption/.github/FUNDING.yml +0 -2
- package/vendor/phpoption/phpoption/.github/SECURITY.md +0 -14
- package/vendor/phpoption/phpoption/.github/workflows/static.yml +0 -74
- package/vendor/phpoption/phpoption/.github/workflows/tests.yml +0 -40
- package/vendor/phpoption/phpoption/LICENSE +0 -201
- package/vendor/phpoption/phpoption/Makefile +0 -26
- package/vendor/phpoption/phpoption/README.md +0 -194
- package/vendor/phpoption/phpoption/composer.json +0 -52
- package/vendor/phpoption/phpoption/phpstan-baseline.neon +0 -32
- package/vendor/phpoption/phpoption/phpstan.neon.dist +0 -8
- package/vendor/phpoption/phpoption/phpunit.xml.dist +0 -13
- package/vendor/phpoption/phpoption/psalm.xml +0 -12
- package/vendor/phpoption/phpoption/src/PhpOption/LazyOption.php +0 -175
- package/vendor/phpoption/phpoption/src/PhpOption/None.php +0 -136
- package/vendor/phpoption/phpoption/src/PhpOption/Option.php +0 -434
- package/vendor/phpoption/phpoption/src/PhpOption/Some.php +0 -169
- package/vendor/phpoption/phpoption/tests/PhpOption/Tests/EnsureTest.php +0 -77
- package/vendor/phpoption/phpoption/tests/PhpOption/Tests/LazyOptionTest.php +0 -200
- package/vendor/phpoption/phpoption/tests/PhpOption/Tests/NoneTest.php +0 -153
- package/vendor/phpoption/phpoption/tests/PhpOption/Tests/OptionTest.php +0 -160
- package/vendor/phpoption/phpoption/tests/PhpOption/Tests/SomeTest.php +0 -194
- package/vendor/phpoption/phpoption/tests/bootstrap.php +0 -8
- package/vendor/phpoption/phpoption/vendor-bin/phpstan/composer.json +0 -8
- package/vendor/phpoption/phpoption/vendor-bin/psalm/composer.json +0 -8
- package/vendor/ramsey/uuid/.editorconfig +0 -16
- package/vendor/ramsey/uuid/.gitattributes +0 -26
- package/vendor/ramsey/uuid/.github/CODEOWNERS +0 -1
- package/vendor/ramsey/uuid/.github/FUNDING.yml +0 -2
- package/vendor/ramsey/uuid/.github/ISSUE_TEMPLATE/Bug_Report.md +0 -35
- package/vendor/ramsey/uuid/.github/ISSUE_TEMPLATE/Feature_Request.md +0 -31
- package/vendor/ramsey/uuid/.github/ISSUE_TEMPLATE/Question.md +0 -19
- package/vendor/ramsey/uuid/.github/ISSUE_TEMPLATE/config.yml +0 -1
- package/vendor/ramsey/uuid/.github/dependabot.yml +0 -15
- package/vendor/ramsey/uuid/.github/pull_request_template.md +0 -27
- package/vendor/ramsey/uuid/.github/workflows/continuous-integration.yml +0 -181
- package/vendor/ramsey/uuid/.github/workflows/merge-dependabot-upgrades.yml +0 -24
- package/vendor/ramsey/uuid/.readthedocs.yml +0 -11
- package/vendor/ramsey/uuid/CHANGELOG.md +0 -1511
- package/vendor/ramsey/uuid/CODE_OF_CONDUCT.md +0 -73
- package/vendor/ramsey/uuid/CONTRIBUTING.md +0 -171
- package/vendor/ramsey/uuid/LICENSE +0 -19
- package/vendor/ramsey/uuid/README.md +0 -83
- package/vendor/ramsey/uuid/SECURITY.md +0 -170
- package/vendor/ramsey/uuid/build/.gitignore +0 -6
- package/vendor/ramsey/uuid/build/cache/.gitkeep +0 -0
- package/vendor/ramsey/uuid/build/logs/.gitkeep +0 -0
- package/vendor/ramsey/uuid/captainhook.json +0 -105
- package/vendor/ramsey/uuid/codecov.yml +0 -29
- package/vendor/ramsey/uuid/composer.json +0 -106
- package/vendor/ramsey/uuid/composer.lock +0 -7208
- package/vendor/ramsey/uuid/docs/Makefile +0 -20
- package/vendor/ramsey/uuid/docs/README.md +0 -36
- package/vendor/ramsey/uuid/docs/_static/.gitkeep +0 -0
- package/vendor/ramsey/uuid/docs/conf.py +0 -103
- package/vendor/ramsey/uuid/docs/copyright.rst +0 -18
- package/vendor/ramsey/uuid/docs/customize/calculators.rst +0 -75
- package/vendor/ramsey/uuid/docs/customize/factory.rst +0 -93
- package/vendor/ramsey/uuid/docs/customize/ordered-time-codec.rst +0 -86
- package/vendor/ramsey/uuid/docs/customize/timestamp-first-comb-codec.rst +0 -72
- package/vendor/ramsey/uuid/docs/customize/validators.rst +0 -39
- package/vendor/ramsey/uuid/docs/customize.rst +0 -56
- package/vendor/ramsey/uuid/docs/database.rst +0 -260
- package/vendor/ramsey/uuid/docs/faq.rst +0 -132
- package/vendor/ramsey/uuid/docs/index.rst +0 -51
- package/vendor/ramsey/uuid/docs/introduction.rst +0 -31
- package/vendor/ramsey/uuid/docs/nonstandard/guid.rst +0 -152
- package/vendor/ramsey/uuid/docs/nonstandard/other.rst +0 -49
- package/vendor/ramsey/uuid/docs/nonstandard/version6.rst +0 -17
- package/vendor/ramsey/uuid/docs/nonstandard.rst +0 -40
- package/vendor/ramsey/uuid/docs/quickstart.rst +0 -112
- package/vendor/ramsey/uuid/docs/reference/calculators.rst +0 -168
- package/vendor/ramsey/uuid/docs/reference/exceptions.rst +0 -92
- package/vendor/ramsey/uuid/docs/reference/fields-fieldsinterface.rst +0 -16
- package/vendor/ramsey/uuid/docs/reference/guid-fields.rst +0 -13
- package/vendor/ramsey/uuid/docs/reference/guid-guid.rst +0 -20
- package/vendor/ramsey/uuid/docs/reference/helper.rst +0 -62
- package/vendor/ramsey/uuid/docs/reference/name-based-namespaces.rst +0 -31
- package/vendor/ramsey/uuid/docs/reference/nonstandard-fields.rst +0 -13
- package/vendor/ramsey/uuid/docs/reference/nonstandard-uuid.rst +0 -20
- package/vendor/ramsey/uuid/docs/reference/nonstandard-uuidv6.rst +0 -34
- package/vendor/ramsey/uuid/docs/reference/rfc4122-fieldsinterface.rst +0 -78
- package/vendor/ramsey/uuid/docs/reference/rfc4122-uuidinterface.rst +0 -20
- package/vendor/ramsey/uuid/docs/reference/rfc4122-uuidv1.rst +0 -21
- package/vendor/ramsey/uuid/docs/reference/rfc4122-uuidv2.rst +0 -47
- package/vendor/ramsey/uuid/docs/reference/rfc4122-uuidv3.rst +0 -13
- package/vendor/ramsey/uuid/docs/reference/rfc4122-uuidv4.rst +0 -13
- package/vendor/ramsey/uuid/docs/reference/rfc4122-uuidv5.rst +0 -13
- package/vendor/ramsey/uuid/docs/reference/rfc4122-uuidv6.rst +0 -31
- package/vendor/ramsey/uuid/docs/reference/rfc4122-uuidv7.rst +0 -20
- package/vendor/ramsey/uuid/docs/reference/rfc4122-uuidv8.rst +0 -13
- package/vendor/ramsey/uuid/docs/reference/rfc4122-version.rst +0 -87
- package/vendor/ramsey/uuid/docs/reference/timebaseduuidinterface.rst +0 -16
- package/vendor/ramsey/uuid/docs/reference/types.rst +0 -79
- package/vendor/ramsey/uuid/docs/reference/uuid.rst +0 -161
- package/vendor/ramsey/uuid/docs/reference/uuidfactoryinterface.rst +0 -102
- package/vendor/ramsey/uuid/docs/reference/uuidinterface.rst +0 -60
- package/vendor/ramsey/uuid/docs/reference/validators.rst +0 -34
- package/vendor/ramsey/uuid/docs/reference/variant.rst +0 -32
- package/vendor/ramsey/uuid/docs/reference.rst +0 -37
- package/vendor/ramsey/uuid/docs/requirements.txt +0 -3
- package/vendor/ramsey/uuid/docs/rfc4122/version1.rst +0 -192
- package/vendor/ramsey/uuid/docs/rfc4122/version2.rst +0 -273
- package/vendor/ramsey/uuid/docs/rfc4122/version3.rst +0 -68
- package/vendor/ramsey/uuid/docs/rfc4122/version4.rst +0 -39
- package/vendor/ramsey/uuid/docs/rfc4122/version5.rst +0 -108
- package/vendor/ramsey/uuid/docs/rfc4122/version6.rst +0 -213
- package/vendor/ramsey/uuid/docs/rfc4122/version7.rst +0 -173
- package/vendor/ramsey/uuid/docs/rfc4122/version8.rst +0 -51
- package/vendor/ramsey/uuid/docs/rfc4122.rst +0 -67
- package/vendor/ramsey/uuid/docs/testing.rst +0 -199
- package/vendor/ramsey/uuid/docs/tidelift.rst +0 -74
- package/vendor/ramsey/uuid/docs/upgrading/2-to-3.rst +0 -31
- package/vendor/ramsey/uuid/docs/upgrading/3-to-4.rst +0 -512
- package/vendor/ramsey/uuid/docs/upgrading.rst +0 -11
- package/vendor/ramsey/uuid/phpbench.json +0 -10
- package/vendor/ramsey/uuid/phpcs.xml.dist +0 -476
- package/vendor/ramsey/uuid/phpstan-tests.neon +0 -32
- package/vendor/ramsey/uuid/phpstan.neon.dist +0 -25
- package/vendor/ramsey/uuid/phpunit.xml.dist +0 -26
- package/vendor/ramsey/uuid/psalm-baseline.xml +0 -133
- package/vendor/ramsey/uuid/psalm.xml +0 -25
- package/vendor/ramsey/uuid/resources/vagrant/README.md +0 -10
- package/vendor/ramsey/uuid/resources/vagrant/freebsd/README.md +0 -15
- package/vendor/ramsey/uuid/resources/vagrant/freebsd/Vagrantfile +0 -35
- package/vendor/ramsey/uuid/resources/vagrant/linux/README.md +0 -15
- package/vendor/ramsey/uuid/resources/vagrant/linux/Vagrantfile +0 -27
- package/vendor/ramsey/uuid/resources/vagrant/windows/README.md +0 -16
- package/vendor/ramsey/uuid/resources/vagrant/windows/Vagrantfile +0 -22
- package/vendor/ramsey/uuid/src/BinaryUtils.php +0 -106
- package/vendor/ramsey/uuid/src/Builder/FallbackBuilder.php +0 -68
- package/vendor/ramsey/uuid/src/Builder/UuidBuilderInterface.php +0 -39
- package/vendor/ramsey/uuid/src/Codec/CodecInterface.php +0 -67
- package/vendor/ramsey/uuid/src/Codec/GuidStringCodec.php +0 -82
- package/vendor/ramsey/uuid/src/Codec/OrderedTimeCodec.php +0 -114
- package/vendor/ramsey/uuid/src/Codec/StringCodec.php +0 -128
- package/vendor/ramsey/uuid/src/Codec/TimestampFirstCombCodec.php +0 -105
- package/vendor/ramsey/uuid/src/Codec/TimestampLastCombCodec.php +0 -51
- package/vendor/ramsey/uuid/src/Converter/Number/GenericNumberConverter.php +0 -48
- package/vendor/ramsey/uuid/src/Converter/NumberConverterInterface.php +0 -53
- package/vendor/ramsey/uuid/src/Converter/Time/GenericTimeConverter.php +0 -118
- package/vendor/ramsey/uuid/src/Converter/Time/PhpTimeConverter.php +0 -163
- package/vendor/ramsey/uuid/src/Converter/Time/UnixTimeConverter.php +0 -90
- package/vendor/ramsey/uuid/src/Converter/TimeConverterInterface.php +0 -58
- package/vendor/ramsey/uuid/src/Exception/BuilderNotFoundException.php +0 -24
- package/vendor/ramsey/uuid/src/Exception/DateTimeException.php +0 -24
- package/vendor/ramsey/uuid/src/Exception/DceSecurityException.php +0 -25
- package/vendor/ramsey/uuid/src/Exception/InvalidArgumentException.php +0 -24
- package/vendor/ramsey/uuid/src/Exception/InvalidBytesException.php +0 -24
- package/vendor/ramsey/uuid/src/Exception/InvalidUuidStringException.php +0 -25
- package/vendor/ramsey/uuid/src/Exception/NameException.php +0 -25
- package/vendor/ramsey/uuid/src/Exception/NodeException.php +0 -24
- package/vendor/ramsey/uuid/src/Exception/RandomSourceException.php +0 -27
- package/vendor/ramsey/uuid/src/Exception/TimeSourceException.php +0 -24
- package/vendor/ramsey/uuid/src/Exception/UnableToBuildUuidException.php +0 -24
- package/vendor/ramsey/uuid/src/Exception/UnsupportedOperationException.php +0 -24
- package/vendor/ramsey/uuid/src/Exception/UuidExceptionInterface.php +0 -21
- package/vendor/ramsey/uuid/src/FeatureSet.php +0 -395
- package/vendor/ramsey/uuid/src/Fields/FieldsInterface.php +0 -42
- package/vendor/ramsey/uuid/src/Fields/SerializableFieldsTrait.php +0 -70
- package/vendor/ramsey/uuid/src/Generator/CombGenerator.php +0 -124
- package/vendor/ramsey/uuid/src/Generator/DceSecurityGenerator.php +0 -139
- package/vendor/ramsey/uuid/src/Generator/DceSecurityGeneratorInterface.php +0 -53
- package/vendor/ramsey/uuid/src/Generator/DefaultNameGenerator.php +0 -51
- package/vendor/ramsey/uuid/src/Generator/DefaultTimeGenerator.php +0 -131
- package/vendor/ramsey/uuid/src/Generator/NameGeneratorFactory.php +0 -30
- package/vendor/ramsey/uuid/src/Generator/NameGeneratorInterface.php +0 -38
- package/vendor/ramsey/uuid/src/Generator/PeclUuidNameGenerator.php +0 -52
- package/vendor/ramsey/uuid/src/Generator/PeclUuidRandomGenerator.php +0 -37
- package/vendor/ramsey/uuid/src/Generator/PeclUuidTimeGenerator.php +0 -39
- package/vendor/ramsey/uuid/src/Generator/RandomBytesGenerator.php +0 -45
- package/vendor/ramsey/uuid/src/Generator/RandomGeneratorFactory.php +0 -30
- package/vendor/ramsey/uuid/src/Generator/RandomGeneratorInterface.php +0 -31
- package/vendor/ramsey/uuid/src/Generator/TimeGeneratorFactory.php +0 -45
- package/vendor/ramsey/uuid/src/Generator/TimeGeneratorInterface.php +0 -38
- package/vendor/ramsey/uuid/src/Generator/UnixTimeGenerator.php +0 -170
- package/vendor/ramsey/uuid/src/Guid/Fields.php +0 -208
- package/vendor/ramsey/uuid/src/Guid/Guid.php +0 -61
- package/vendor/ramsey/uuid/src/Guid/GuidBuilder.php +0 -79
- package/vendor/ramsey/uuid/src/Lazy/LazyUuidFromString.php +0 -226
- package/vendor/ramsey/uuid/src/Math/BrickMathCalculator.php +0 -145
- package/vendor/ramsey/uuid/src/Math/CalculatorInterface.php +0 -106
- package/vendor/ramsey/uuid/src/Math/RoundingMode.php +0 -146
- package/vendor/ramsey/uuid/src/Nonstandard/Fields.php +0 -154
- package/vendor/ramsey/uuid/src/Nonstandard/Uuid.php +0 -37
- package/vendor/ramsey/uuid/src/Nonstandard/UuidBuilder.php +0 -78
- package/vendor/ramsey/uuid/src/Nonstandard/UuidV6.php +0 -113
- package/vendor/ramsey/uuid/src/Provider/Dce/SystemDceSecurityProvider.php +0 -236
- package/vendor/ramsey/uuid/src/Provider/DceSecurityProviderInterface.php +0 -41
- package/vendor/ramsey/uuid/src/Provider/Node/FallbackNodeProvider.php +0 -54
- package/vendor/ramsey/uuid/src/Provider/Node/RandomNodeProvider.php +0 -69
- package/vendor/ramsey/uuid/src/Provider/Node/StaticNodeProvider.php +0 -74
- package/vendor/ramsey/uuid/src/Provider/Node/SystemNodeProvider.php +0 -190
- package/vendor/ramsey/uuid/src/Provider/NodeProviderInterface.php +0 -30
- package/vendor/ramsey/uuid/src/Provider/Time/FixedTimeProvider.php +0 -57
- package/vendor/ramsey/uuid/src/Provider/Time/SystemTimeProvider.php +0 -33
- package/vendor/ramsey/uuid/src/Provider/TimeProviderInterface.php +0 -28
- package/vendor/ramsey/uuid/src/Rfc4122/Fields.php +0 -214
- package/vendor/ramsey/uuid/src/Rfc4122/FieldsInterface.php +0 -129
- package/vendor/ramsey/uuid/src/Rfc4122/MaxTrait.php +0 -41
- package/vendor/ramsey/uuid/src/Rfc4122/MaxUuid.php +0 -27
- package/vendor/ramsey/uuid/src/Rfc4122/NilTrait.php +0 -41
- package/vendor/ramsey/uuid/src/Rfc4122/NilUuid.php +0 -27
- package/vendor/ramsey/uuid/src/Rfc4122/TimeTrait.php +0 -55
- package/vendor/ramsey/uuid/src/Rfc4122/UuidBuilder.php +0 -116
- package/vendor/ramsey/uuid/src/Rfc4122/UuidInterface.php +0 -30
- package/vendor/ramsey/uuid/src/Rfc4122/UuidV1.php +0 -61
- package/vendor/ramsey/uuid/src/Rfc4122/UuidV2.php +0 -119
- package/vendor/ramsey/uuid/src/Rfc4122/UuidV3.php +0 -58
- package/vendor/ramsey/uuid/src/Rfc4122/UuidV4.php +0 -58
- package/vendor/ramsey/uuid/src/Rfc4122/UuidV5.php +0 -58
- package/vendor/ramsey/uuid/src/Rfc4122/UuidV6.php +0 -30
- package/vendor/ramsey/uuid/src/Rfc4122/UuidV7.php +0 -63
- package/vendor/ramsey/uuid/src/Rfc4122/UuidV8.php +0 -65
- package/vendor/ramsey/uuid/src/Rfc4122/Validator.php +0 -45
- package/vendor/ramsey/uuid/src/Rfc4122/VariantTrait.php +0 -87
- package/vendor/ramsey/uuid/src/Rfc4122/Version.php +0 -139
- package/vendor/ramsey/uuid/src/Rfc4122/VersionTrait.php +0 -57
- package/vendor/ramsey/uuid/src/TimeBasedUuidFactoryInterface.php +0 -48
- package/vendor/ramsey/uuid/src/TimeBasedUuidInterface.php +0 -30
- package/vendor/ramsey/uuid/src/Type/Decimal.php +0 -135
- package/vendor/ramsey/uuid/src/Type/Hexadecimal.php +0 -109
- package/vendor/ramsey/uuid/src/Type/Integer.php +0 -145
- package/vendor/ramsey/uuid/src/Type/NumberInterface.php +0 -28
- package/vendor/ramsey/uuid/src/Type/Time.php +0 -108
- package/vendor/ramsey/uuid/src/Type/TypeInterface.php +0 -45
- package/vendor/ramsey/uuid/src/Uuid.php +0 -645
- package/vendor/ramsey/uuid/src/UuidFactory.php +0 -503
- package/vendor/ramsey/uuid/src/UuidFactoryInterface.php +0 -184
- package/vendor/ramsey/uuid/src/UuidInterface.php +0 -114
- package/vendor/ramsey/uuid/src/Validator/GenericValidator.php +0 -45
- package/vendor/ramsey/uuid/src/Validator/ValidatorInterface.php +0 -39
- package/vendor/ramsey/uuid/src/Variant.php +0 -60
- package/vendor/ramsey/uuid/src/functions.php +0 -160
- package/vendor/ramsey/uuid/tests/BinaryUtilsTest.php +0 -381
- package/vendor/ramsey/uuid/tests/Builder/FallbackBuilderTest.php +0 -198
- package/vendor/ramsey/uuid/tests/Codec/GuidStringCodecTest.php +0 -118
- package/vendor/ramsey/uuid/tests/Codec/OrderedTimeCodecTest.php +0 -258
- package/vendor/ramsey/uuid/tests/Codec/StringCodecTest.php +0 -149
- package/vendor/ramsey/uuid/tests/Converter/Number/GenericNumberConverterTest.php +0 -28
- package/vendor/ramsey/uuid/tests/Converter/Time/GenericTimeConverterTest.php +0 -147
- package/vendor/ramsey/uuid/tests/Converter/Time/PhpTimeConverterTest.php +0 -199
- package/vendor/ramsey/uuid/tests/Converter/Time/UnixTimeConverterTest.php +0 -202
- package/vendor/ramsey/uuid/tests/Encoder/TimestampFirstCombCodecTest.php +0 -105
- package/vendor/ramsey/uuid/tests/Encoder/TimestampLastCombCodecTest.php +0 -106
- package/vendor/ramsey/uuid/tests/ExpectedBehaviorTest.php +0 -573
- package/vendor/ramsey/uuid/tests/FeatureSetTest.php +0 -88
- package/vendor/ramsey/uuid/tests/FunctionsTest.php +0 -151
- package/vendor/ramsey/uuid/tests/Generator/CombGeneratorTest.php +0 -134
- package/vendor/ramsey/uuid/tests/Generator/DceSecurityGeneratorTest.php +0 -282
- package/vendor/ramsey/uuid/tests/Generator/DefaultNameGeneratorTest.php +0 -83
- package/vendor/ramsey/uuid/tests/Generator/DefaultTimeGeneratorTest.php +0 -202
- package/vendor/ramsey/uuid/tests/Generator/NameGeneratorFactoryTest.php +0 -19
- package/vendor/ramsey/uuid/tests/Generator/PeclUuidNameGeneratorTest.php +0 -107
- package/vendor/ramsey/uuid/tests/Generator/PeclUuidRandomGeneratorTest.php +0 -30
- package/vendor/ramsey/uuid/tests/Generator/PeclUuidTimeGeneratorTest.php +0 -30
- package/vendor/ramsey/uuid/tests/Generator/RandomBytesGeneratorTest.php +0 -70
- package/vendor/ramsey/uuid/tests/Generator/RandomGeneratorFactoryTest.php +0 -19
- package/vendor/ramsey/uuid/tests/Generator/TimeGeneratorFactoryTest.php +0 -33
- package/vendor/ramsey/uuid/tests/Generator/UnixTimeGeneratorTest.php +0 -204
- package/vendor/ramsey/uuid/tests/Guid/FieldsTest.php +0 -235
- package/vendor/ramsey/uuid/tests/Guid/GuidBuilderTest.php +0 -33
- package/vendor/ramsey/uuid/tests/Math/BrickMathCalculatorTest.php +0 -116
- package/vendor/ramsey/uuid/tests/Nonstandard/FieldsTest.php +0 -84
- package/vendor/ramsey/uuid/tests/Nonstandard/UuidBuilderTest.php +0 -33
- package/vendor/ramsey/uuid/tests/Nonstandard/UuidV6Test.php +0 -192
- package/vendor/ramsey/uuid/tests/Provider/Dce/SystemDceSecurityProviderTest.php +0 -505
- package/vendor/ramsey/uuid/tests/Provider/Node/FallbackNodeProviderTest.php +0 -87
- package/vendor/ramsey/uuid/tests/Provider/Node/RandomNodeProviderTest.php +0 -124
- package/vendor/ramsey/uuid/tests/Provider/Node/StaticNodeProviderTest.php +0 -58
- package/vendor/ramsey/uuid/tests/Provider/Node/SystemNodeProviderTest.php +0 -950
- package/vendor/ramsey/uuid/tests/Provider/Time/FixedTimeProviderTest.php +0 -41
- package/vendor/ramsey/uuid/tests/Provider/Time/SystemTimeProviderTest.php +0 -20
- package/vendor/ramsey/uuid/tests/Rfc4122/FieldsTest.php +0 -260
- package/vendor/ramsey/uuid/tests/Rfc4122/UuidBuilderTest.php +0 -145
- package/vendor/ramsey/uuid/tests/Rfc4122/UuidV1Test.php +0 -123
- package/vendor/ramsey/uuid/tests/Rfc4122/UuidV2Test.php +0 -214
- package/vendor/ramsey/uuid/tests/Rfc4122/UuidV3Test.php +0 -56
- package/vendor/ramsey/uuid/tests/Rfc4122/UuidV4Test.php +0 -56
- package/vendor/ramsey/uuid/tests/Rfc4122/UuidV5Test.php +0 -56
- package/vendor/ramsey/uuid/tests/Rfc4122/UuidV6Test.php +0 -221
- package/vendor/ramsey/uuid/tests/Rfc4122/UuidV7Test.php +0 -131
- package/vendor/ramsey/uuid/tests/Rfc4122/UuidV8Test.php +0 -56
- package/vendor/ramsey/uuid/tests/Rfc4122/ValidatorTest.php +0 -122
- package/vendor/ramsey/uuid/tests/Rfc4122/VariantTraitTest.php +0 -109
- package/vendor/ramsey/uuid/tests/TestCase.php +0 -29
- package/vendor/ramsey/uuid/tests/Type/DecimalTest.php +0 -305
- package/vendor/ramsey/uuid/tests/Type/HexadecimalTest.php +0 -112
- package/vendor/ramsey/uuid/tests/Type/IntegerTest.php +0 -235
- package/vendor/ramsey/uuid/tests/Type/TimeTest.php +0 -120
- package/vendor/ramsey/uuid/tests/UuidFactoryTest.php +0 -233
- package/vendor/ramsey/uuid/tests/UuidTest.php +0 -1910
- package/vendor/ramsey/uuid/tests/Validator/GenericValidatorTest.php +0 -98
- package/vendor/ramsey/uuid/tests/benchmark/GuidConversionBench.php +0 -43
- package/vendor/ramsey/uuid/tests/benchmark/NonLazyUuidConversionBench.php +0 -39
- package/vendor/ramsey/uuid/tests/benchmark/UuidFieldExtractionBench.php +0 -86
- package/vendor/ramsey/uuid/tests/benchmark/UuidGenerationBench.php +0 -113
- package/vendor/ramsey/uuid/tests/benchmark/UuidSerializationBench.php +0 -206
- package/vendor/ramsey/uuid/tests/benchmark/UuidStringConversionBench.php +0 -257
- package/vendor/ramsey/uuid/tests/bootstrap.php +0 -12
- package/vendor/ramsey/uuid/tests/static-analysis/UuidIsImmutable.php +0 -96
- package/vendor/ramsey/uuid/tests/static-analysis/UuidIsNeverEmpty.php +0 -36
- package/vendor/ramsey/uuid/tests/static-analysis/ValidUuidIsNonEmpty.php +0 -44
- package/vendor/ramsey/uuid/tests/static-analysis/stubs.php +0 -33
- package/vendor/symfony/polyfill-ctype/Ctype.php +0 -232
- package/vendor/symfony/polyfill-ctype/LICENSE +0 -19
- package/vendor/symfony/polyfill-ctype/README.md +0 -12
- package/vendor/symfony/polyfill-ctype/bootstrap.php +0 -50
- package/vendor/symfony/polyfill-ctype/bootstrap80.php +0 -46
- package/vendor/symfony/polyfill-ctype/composer.json +0 -41
- package/vendor/symfony/polyfill-mbstring/LICENSE +0 -19
- package/vendor/symfony/polyfill-mbstring/Mbstring.php +0 -947
- package/vendor/symfony/polyfill-mbstring/README.md +0 -13
- package/vendor/symfony/polyfill-mbstring/Resources/unidata/caseFolding.php +0 -119
- package/vendor/symfony/polyfill-mbstring/Resources/unidata/lowerCase.php +0 -1397
- package/vendor/symfony/polyfill-mbstring/Resources/unidata/titleCaseRegexp.php +0 -5
- package/vendor/symfony/polyfill-mbstring/Resources/unidata/upperCase.php +0 -1489
- package/vendor/symfony/polyfill-mbstring/bootstrap.php +0 -151
- package/vendor/symfony/polyfill-mbstring/bootstrap80.php +0 -147
- package/vendor/symfony/polyfill-mbstring/composer.json +0 -41
- package/vendor/symfony/polyfill-php80/LICENSE +0 -19
- package/vendor/symfony/polyfill-php80/Php80.php +0 -115
- package/vendor/symfony/polyfill-php80/PhpToken.php +0 -103
- package/vendor/symfony/polyfill-php80/README.md +0 -25
- package/vendor/symfony/polyfill-php80/Resources/stubs/Attribute.php +0 -31
- package/vendor/symfony/polyfill-php80/Resources/stubs/PhpToken.php +0 -16
- package/vendor/symfony/polyfill-php80/Resources/stubs/Stringable.php +0 -20
- package/vendor/symfony/polyfill-php80/Resources/stubs/UnhandledMatchError.php +0 -16
- package/vendor/symfony/polyfill-php80/Resources/stubs/ValueError.php +0 -16
- package/vendor/symfony/polyfill-php80/bootstrap.php +0 -42
- package/vendor/symfony/polyfill-php80/composer.json +0 -40
- package/vendor/vlucas/phpdotenv/.editorconfig +0 -15
- package/vendor/vlucas/phpdotenv/.gitattributes +0 -17
- package/vendor/vlucas/phpdotenv/.github/CODE_OF_CONDUCT.md +0 -132
- package/vendor/vlucas/phpdotenv/.github/CONTRIBUTING.md +0 -30
- package/vendor/vlucas/phpdotenv/.github/FUNDING.yml +0 -2
- package/vendor/vlucas/phpdotenv/.github/SECURITY.md +0 -14
- package/vendor/vlucas/phpdotenv/.github/workflows/static.yml +0 -74
- package/vendor/vlucas/phpdotenv/.github/workflows/tests.yml +0 -70
- package/vendor/vlucas/phpdotenv/LICENSE +0 -30
- package/vendor/vlucas/phpdotenv/Makefile +0 -26
- package/vendor/vlucas/phpdotenv/README.md +0 -363
- package/vendor/vlucas/phpdotenv/UPGRADING.md +0 -196
- package/vendor/vlucas/phpdotenv/composer.json +0 -60
- package/vendor/vlucas/phpdotenv/phpstan-baseline.neon +0 -21
- package/vendor/vlucas/phpdotenv/phpstan.neon.dist +0 -7
- package/vendor/vlucas/phpdotenv/phpunit.xml.dist +0 -13
- package/vendor/vlucas/phpdotenv/psalm-baseline.xml +0 -28
- package/vendor/vlucas/phpdotenv/psalm.xml +0 -13
- package/vendor/vlucas/phpdotenv/src/Dotenv.php +0 -267
- package/vendor/vlucas/phpdotenv/src/Exception/ExceptionInterface.php +0 -12
- package/vendor/vlucas/phpdotenv/src/Exception/InvalidEncodingException.php +0 -12
- package/vendor/vlucas/phpdotenv/src/Exception/InvalidFileException.php +0 -12
- package/vendor/vlucas/phpdotenv/src/Exception/InvalidPathException.php +0 -12
- package/vendor/vlucas/phpdotenv/src/Exception/ValidationException.php +0 -12
- package/vendor/vlucas/phpdotenv/src/Loader/Loader.php +0 -47
- package/vendor/vlucas/phpdotenv/src/Loader/LoaderInterface.php +0 -20
- package/vendor/vlucas/phpdotenv/src/Loader/Resolver.php +0 -65
- package/vendor/vlucas/phpdotenv/src/Parser/Entry.php +0 -59
- package/vendor/vlucas/phpdotenv/src/Parser/EntryParser.php +0 -300
- package/vendor/vlucas/phpdotenv/src/Parser/Lexer.php +0 -58
- package/vendor/vlucas/phpdotenv/src/Parser/Lines.php +0 -127
- package/vendor/vlucas/phpdotenv/src/Parser/Parser.php +0 -53
- package/vendor/vlucas/phpdotenv/src/Parser/ParserInterface.php +0 -19
- package/vendor/vlucas/phpdotenv/src/Parser/Value.php +0 -88
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/AdapterInterface.php +0 -15
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/ApacheAdapter.php +0 -89
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/ArrayAdapter.php +0 -80
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/EnvConstAdapter.php +0 -89
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/GuardedWriter.php +0 -85
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/ImmutableWriter.php +0 -110
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/MultiReader.php +0 -48
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/MultiWriter.php +0 -64
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/PutenvAdapter.php +0 -91
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/ReaderInterface.php +0 -17
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/ReplacingWriter.php +0 -104
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/ServerConstAdapter.php +0 -89
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/WriterInterface.php +0 -27
- package/vendor/vlucas/phpdotenv/src/Repository/AdapterRepository.php +0 -107
- package/vendor/vlucas/phpdotenv/src/Repository/RepositoryBuilder.php +0 -272
- package/vendor/vlucas/phpdotenv/src/Repository/RepositoryInterface.php +0 -51
- package/vendor/vlucas/phpdotenv/src/Store/File/Paths.php +0 -44
- package/vendor/vlucas/phpdotenv/src/Store/File/Reader.php +0 -81
- package/vendor/vlucas/phpdotenv/src/Store/FileStore.php +0 -72
- package/vendor/vlucas/phpdotenv/src/Store/StoreBuilder.php +0 -141
- package/vendor/vlucas/phpdotenv/src/Store/StoreInterface.php +0 -17
- package/vendor/vlucas/phpdotenv/src/Store/StringStore.php +0 -37
- package/vendor/vlucas/phpdotenv/src/Util/Regex.php +0 -112
- package/vendor/vlucas/phpdotenv/src/Util/Str.php +0 -98
- package/vendor/vlucas/phpdotenv/src/Validator.php +0 -209
- package/vendor/vlucas/phpdotenv/tests/Dotenv/DotenvTest.php +0 -387
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Loader/LoaderTest.php +0 -86
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Parser/EntryParserTest.php +0 -234
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Parser/LexerTest.php +0 -40
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Parser/LinesTest.php +0 -53
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Parser/ParserTest.php +0 -98
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/Adapter/ArrayAdapterTest.php +0 -57
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/Adapter/EnvConstAdapterTest.php +0 -75
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/Adapter/PutenvAdapterTest.php +0 -52
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/Adapter/ServerConstAdapterTest.php +0 -75
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/RepositoryTest.php +0 -305
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Store/StoreTest.php +0 -141
- package/vendor/vlucas/phpdotenv/tests/Dotenv/ValidatorTest.php +0 -479
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/.env +0 -5
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/assertions.env +0 -18
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/booleans.env +0 -33
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/commented.env +0 -15
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/empty.env +0 -1
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/example.env +0 -1
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/exported.env +0 -7
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/immutable.env +0 -1
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/integers.env +0 -17
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/large.env +0 -2
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/multibyte.env +0 -3
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/multiline.env +0 -14
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/multiple.env +0 -4
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/mutable.env +0 -1
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/nested.env +0 -15
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/quoted.env +0 -11
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/specialchars.env +0 -8
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/unicodevarnames.env +0 -2
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/utf8-with-bom-encoding.env +0 -3
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/windows.env +0 -1
- package/vendor/vlucas/phpdotenv/vendor-bin/phpstan/composer.json +0 -16
- package/vendor/vlucas/phpdotenv/vendor-bin/psalm/composer.json +0 -9
|
@@ -1,268 +0,0 @@
|
|
|
1
|
-
<?php
|
|
2
|
-
|
|
3
|
-
namespace Firebase\JWT;
|
|
4
|
-
|
|
5
|
-
use ArrayAccess;
|
|
6
|
-
use InvalidArgumentException;
|
|
7
|
-
use LogicException;
|
|
8
|
-
use OutOfBoundsException;
|
|
9
|
-
use Psr\Cache\CacheItemInterface;
|
|
10
|
-
use Psr\Cache\CacheItemPoolInterface;
|
|
11
|
-
use Psr\Http\Client\ClientInterface;
|
|
12
|
-
use Psr\Http\Message\RequestFactoryInterface;
|
|
13
|
-
use RuntimeException;
|
|
14
|
-
use UnexpectedValueException;
|
|
15
|
-
|
|
16
|
-
/**
|
|
17
|
-
* @implements ArrayAccess<string, Key>
|
|
18
|
-
*/
|
|
19
|
-
class CachedKeySet implements ArrayAccess
|
|
20
|
-
{
|
|
21
|
-
/**
|
|
22
|
-
* @var string
|
|
23
|
-
*/
|
|
24
|
-
private $jwksUri;
|
|
25
|
-
/**
|
|
26
|
-
* @var ClientInterface
|
|
27
|
-
*/
|
|
28
|
-
private $httpClient;
|
|
29
|
-
/**
|
|
30
|
-
* @var RequestFactoryInterface
|
|
31
|
-
*/
|
|
32
|
-
private $httpFactory;
|
|
33
|
-
/**
|
|
34
|
-
* @var CacheItemPoolInterface
|
|
35
|
-
*/
|
|
36
|
-
private $cache;
|
|
37
|
-
/**
|
|
38
|
-
* @var ?int
|
|
39
|
-
*/
|
|
40
|
-
private $expiresAfter;
|
|
41
|
-
/**
|
|
42
|
-
* @var ?CacheItemInterface
|
|
43
|
-
*/
|
|
44
|
-
private $cacheItem;
|
|
45
|
-
/**
|
|
46
|
-
* @var array<string, array<mixed>>
|
|
47
|
-
*/
|
|
48
|
-
private $keySet;
|
|
49
|
-
/**
|
|
50
|
-
* @var string
|
|
51
|
-
*/
|
|
52
|
-
private $cacheKey;
|
|
53
|
-
/**
|
|
54
|
-
* @var string
|
|
55
|
-
*/
|
|
56
|
-
private $cacheKeyPrefix = 'jwks';
|
|
57
|
-
/**
|
|
58
|
-
* @var int
|
|
59
|
-
*/
|
|
60
|
-
private $maxKeyLength = 64;
|
|
61
|
-
/**
|
|
62
|
-
* @var bool
|
|
63
|
-
*/
|
|
64
|
-
private $rateLimit;
|
|
65
|
-
/**
|
|
66
|
-
* @var string
|
|
67
|
-
*/
|
|
68
|
-
private $rateLimitCacheKey;
|
|
69
|
-
/**
|
|
70
|
-
* @var int
|
|
71
|
-
*/
|
|
72
|
-
private $maxCallsPerMinute = 10;
|
|
73
|
-
/**
|
|
74
|
-
* @var string|null
|
|
75
|
-
*/
|
|
76
|
-
private $defaultAlg;
|
|
77
|
-
|
|
78
|
-
public function __construct(
|
|
79
|
-
string $jwksUri,
|
|
80
|
-
ClientInterface $httpClient,
|
|
81
|
-
RequestFactoryInterface $httpFactory,
|
|
82
|
-
CacheItemPoolInterface $cache,
|
|
83
|
-
int $expiresAfter = null,
|
|
84
|
-
bool $rateLimit = false,
|
|
85
|
-
string $defaultAlg = null
|
|
86
|
-
) {
|
|
87
|
-
$this->jwksUri = $jwksUri;
|
|
88
|
-
$this->httpClient = $httpClient;
|
|
89
|
-
$this->httpFactory = $httpFactory;
|
|
90
|
-
$this->cache = $cache;
|
|
91
|
-
$this->expiresAfter = $expiresAfter;
|
|
92
|
-
$this->rateLimit = $rateLimit;
|
|
93
|
-
$this->defaultAlg = $defaultAlg;
|
|
94
|
-
$this->setCacheKeys();
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
/**
|
|
98
|
-
* @param string $keyId
|
|
99
|
-
* @return Key
|
|
100
|
-
*/
|
|
101
|
-
public function offsetGet($keyId): Key
|
|
102
|
-
{
|
|
103
|
-
if (!$this->keyIdExists($keyId)) {
|
|
104
|
-
throw new OutOfBoundsException('Key ID not found');
|
|
105
|
-
}
|
|
106
|
-
return JWK::parseKey($this->keySet[$keyId], $this->defaultAlg);
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
/**
|
|
110
|
-
* @param string $keyId
|
|
111
|
-
* @return bool
|
|
112
|
-
*/
|
|
113
|
-
public function offsetExists($keyId): bool
|
|
114
|
-
{
|
|
115
|
-
return $this->keyIdExists($keyId);
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
/**
|
|
119
|
-
* @param string $offset
|
|
120
|
-
* @param Key $value
|
|
121
|
-
*/
|
|
122
|
-
public function offsetSet($offset, $value): void
|
|
123
|
-
{
|
|
124
|
-
throw new LogicException('Method not implemented');
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
/**
|
|
128
|
-
* @param string $offset
|
|
129
|
-
*/
|
|
130
|
-
public function offsetUnset($offset): void
|
|
131
|
-
{
|
|
132
|
-
throw new LogicException('Method not implemented');
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
/**
|
|
136
|
-
* @return array<mixed>
|
|
137
|
-
*/
|
|
138
|
-
private function formatJwksForCache(string $jwks): array
|
|
139
|
-
{
|
|
140
|
-
$jwks = json_decode($jwks, true);
|
|
141
|
-
|
|
142
|
-
if (!isset($jwks['keys'])) {
|
|
143
|
-
throw new UnexpectedValueException('"keys" member must exist in the JWK Set');
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
if (empty($jwks['keys'])) {
|
|
147
|
-
throw new InvalidArgumentException('JWK Set did not contain any keys');
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
$keys = [];
|
|
151
|
-
foreach ($jwks['keys'] as $k => $v) {
|
|
152
|
-
$kid = isset($v['kid']) ? $v['kid'] : $k;
|
|
153
|
-
$keys[(string) $kid] = $v;
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
return $keys;
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
private function keyIdExists(string $keyId): bool
|
|
160
|
-
{
|
|
161
|
-
if (null === $this->keySet) {
|
|
162
|
-
$item = $this->getCacheItem();
|
|
163
|
-
// Try to load keys from cache
|
|
164
|
-
if ($item->isHit()) {
|
|
165
|
-
// item found! retrieve it
|
|
166
|
-
$this->keySet = $item->get();
|
|
167
|
-
// If the cached item is a string, the JWKS response was cached (previous behavior).
|
|
168
|
-
// Parse this into expected format array<kid, jwk> instead.
|
|
169
|
-
if (\is_string($this->keySet)) {
|
|
170
|
-
$this->keySet = $this->formatJwksForCache($this->keySet);
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
if (!isset($this->keySet[$keyId])) {
|
|
176
|
-
if ($this->rateLimitExceeded()) {
|
|
177
|
-
return false;
|
|
178
|
-
}
|
|
179
|
-
$request = $this->httpFactory->createRequest('GET', $this->jwksUri);
|
|
180
|
-
$jwksResponse = $this->httpClient->sendRequest($request);
|
|
181
|
-
if ($jwksResponse->getStatusCode() !== 200) {
|
|
182
|
-
throw new UnexpectedValueException(
|
|
183
|
-
sprintf('HTTP Error: %d %s for URI "%s"',
|
|
184
|
-
$jwksResponse->getStatusCode(),
|
|
185
|
-
$jwksResponse->getReasonPhrase(),
|
|
186
|
-
$this->jwksUri,
|
|
187
|
-
),
|
|
188
|
-
$jwksResponse->getStatusCode()
|
|
189
|
-
);
|
|
190
|
-
}
|
|
191
|
-
$this->keySet = $this->formatJwksForCache((string) $jwksResponse->getBody());
|
|
192
|
-
|
|
193
|
-
if (!isset($this->keySet[$keyId])) {
|
|
194
|
-
return false;
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
$item = $this->getCacheItem();
|
|
198
|
-
$item->set($this->keySet);
|
|
199
|
-
if ($this->expiresAfter) {
|
|
200
|
-
$item->expiresAfter($this->expiresAfter);
|
|
201
|
-
}
|
|
202
|
-
$this->cache->save($item);
|
|
203
|
-
}
|
|
204
|
-
|
|
205
|
-
return true;
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
private function rateLimitExceeded(): bool
|
|
209
|
-
{
|
|
210
|
-
if (!$this->rateLimit) {
|
|
211
|
-
return false;
|
|
212
|
-
}
|
|
213
|
-
|
|
214
|
-
$cacheItem = $this->cache->getItem($this->rateLimitCacheKey);
|
|
215
|
-
if (!$cacheItem->isHit()) {
|
|
216
|
-
$cacheItem->expiresAfter(60); // # of calls are cached each minute
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
$callsPerMinute = (int) $cacheItem->get();
|
|
220
|
-
if (++$callsPerMinute > $this->maxCallsPerMinute) {
|
|
221
|
-
return true;
|
|
222
|
-
}
|
|
223
|
-
$cacheItem->set($callsPerMinute);
|
|
224
|
-
$this->cache->save($cacheItem);
|
|
225
|
-
return false;
|
|
226
|
-
}
|
|
227
|
-
|
|
228
|
-
private function getCacheItem(): CacheItemInterface
|
|
229
|
-
{
|
|
230
|
-
if (\is_null($this->cacheItem)) {
|
|
231
|
-
$this->cacheItem = $this->cache->getItem($this->cacheKey);
|
|
232
|
-
}
|
|
233
|
-
|
|
234
|
-
return $this->cacheItem;
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
private function setCacheKeys(): void
|
|
238
|
-
{
|
|
239
|
-
if (empty($this->jwksUri)) {
|
|
240
|
-
throw new RuntimeException('JWKS URI is empty');
|
|
241
|
-
}
|
|
242
|
-
|
|
243
|
-
// ensure we do not have illegal characters
|
|
244
|
-
$key = preg_replace('|[^a-zA-Z0-9_\.!]|', '', $this->jwksUri);
|
|
245
|
-
|
|
246
|
-
// add prefix
|
|
247
|
-
$key = $this->cacheKeyPrefix . $key;
|
|
248
|
-
|
|
249
|
-
// Hash keys if they exceed $maxKeyLength of 64
|
|
250
|
-
if (\strlen($key) > $this->maxKeyLength) {
|
|
251
|
-
$key = substr(hash('sha256', $key), 0, $this->maxKeyLength);
|
|
252
|
-
}
|
|
253
|
-
|
|
254
|
-
$this->cacheKey = $key;
|
|
255
|
-
|
|
256
|
-
if ($this->rateLimit) {
|
|
257
|
-
// add prefix
|
|
258
|
-
$rateLimitKey = $this->cacheKeyPrefix . 'ratelimit' . $key;
|
|
259
|
-
|
|
260
|
-
// Hash keys if they exceed $maxKeyLength of 64
|
|
261
|
-
if (\strlen($rateLimitKey) > $this->maxKeyLength) {
|
|
262
|
-
$rateLimitKey = substr(hash('sha256', $rateLimitKey), 0, $this->maxKeyLength);
|
|
263
|
-
}
|
|
264
|
-
|
|
265
|
-
$this->rateLimitCacheKey = $rateLimitKey;
|
|
266
|
-
}
|
|
267
|
-
}
|
|
268
|
-
}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
<?php
|
|
2
|
-
|
|
3
|
-
namespace Firebase\JWT;
|
|
4
|
-
|
|
5
|
-
class ExpiredException extends \UnexpectedValueException implements JWTExceptionWithPayloadInterface
|
|
6
|
-
{
|
|
7
|
-
private object $payload;
|
|
8
|
-
|
|
9
|
-
public function setPayload(object $payload): void
|
|
10
|
-
{
|
|
11
|
-
$this->payload = $payload;
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
public function getPayload(): object
|
|
15
|
-
{
|
|
16
|
-
return $this->payload;
|
|
17
|
-
}
|
|
18
|
-
}
|
|
@@ -1,349 +0,0 @@
|
|
|
1
|
-
<?php
|
|
2
|
-
|
|
3
|
-
namespace Firebase\JWT;
|
|
4
|
-
|
|
5
|
-
use DomainException;
|
|
6
|
-
use InvalidArgumentException;
|
|
7
|
-
use UnexpectedValueException;
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* JSON Web Key implementation, based on this spec:
|
|
11
|
-
* https://tools.ietf.org/html/draft-ietf-jose-json-web-key-41
|
|
12
|
-
*
|
|
13
|
-
* PHP version 5
|
|
14
|
-
*
|
|
15
|
-
* @category Authentication
|
|
16
|
-
* @package Authentication_JWT
|
|
17
|
-
* @author Bui Sy Nguyen <nguyenbs@gmail.com>
|
|
18
|
-
* @license http://opensource.org/licenses/BSD-3-Clause 3-clause BSD
|
|
19
|
-
* @link https://github.com/firebase/php-jwt
|
|
20
|
-
*/
|
|
21
|
-
class JWK
|
|
22
|
-
{
|
|
23
|
-
private const OID = '1.2.840.10045.2.1';
|
|
24
|
-
private const ASN1_OBJECT_IDENTIFIER = 0x06;
|
|
25
|
-
private const ASN1_SEQUENCE = 0x10; // also defined in JWT
|
|
26
|
-
private const ASN1_BIT_STRING = 0x03;
|
|
27
|
-
private const EC_CURVES = [
|
|
28
|
-
'P-256' => '1.2.840.10045.3.1.7', // Len: 64
|
|
29
|
-
'secp256k1' => '1.3.132.0.10', // Len: 64
|
|
30
|
-
'P-384' => '1.3.132.0.34', // Len: 96
|
|
31
|
-
// 'P-521' => '1.3.132.0.35', // Len: 132 (not supported)
|
|
32
|
-
];
|
|
33
|
-
|
|
34
|
-
// For keys with "kty" equal to "OKP" (Octet Key Pair), the "crv" parameter must contain the key subtype.
|
|
35
|
-
// This library supports the following subtypes:
|
|
36
|
-
private const OKP_SUBTYPES = [
|
|
37
|
-
'Ed25519' => true, // RFC 8037
|
|
38
|
-
];
|
|
39
|
-
|
|
40
|
-
/**
|
|
41
|
-
* Parse a set of JWK keys
|
|
42
|
-
*
|
|
43
|
-
* @param array<mixed> $jwks The JSON Web Key Set as an associative array
|
|
44
|
-
* @param string $defaultAlg The algorithm for the Key object if "alg" is not set in the
|
|
45
|
-
* JSON Web Key Set
|
|
46
|
-
*
|
|
47
|
-
* @return array<string, Key> An associative array of key IDs (kid) to Key objects
|
|
48
|
-
*
|
|
49
|
-
* @throws InvalidArgumentException Provided JWK Set is empty
|
|
50
|
-
* @throws UnexpectedValueException Provided JWK Set was invalid
|
|
51
|
-
* @throws DomainException OpenSSL failure
|
|
52
|
-
*
|
|
53
|
-
* @uses parseKey
|
|
54
|
-
*/
|
|
55
|
-
public static function parseKeySet(array $jwks, string $defaultAlg = null): array
|
|
56
|
-
{
|
|
57
|
-
$keys = [];
|
|
58
|
-
|
|
59
|
-
if (!isset($jwks['keys'])) {
|
|
60
|
-
throw new UnexpectedValueException('"keys" member must exist in the JWK Set');
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
if (empty($jwks['keys'])) {
|
|
64
|
-
throw new InvalidArgumentException('JWK Set did not contain any keys');
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
foreach ($jwks['keys'] as $k => $v) {
|
|
68
|
-
$kid = isset($v['kid']) ? $v['kid'] : $k;
|
|
69
|
-
if ($key = self::parseKey($v, $defaultAlg)) {
|
|
70
|
-
$keys[(string) $kid] = $key;
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
if (0 === \count($keys)) {
|
|
75
|
-
throw new UnexpectedValueException('No supported algorithms found in JWK Set');
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
return $keys;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
/**
|
|
82
|
-
* Parse a JWK key
|
|
83
|
-
*
|
|
84
|
-
* @param array<mixed> $jwk An individual JWK
|
|
85
|
-
* @param string $defaultAlg The algorithm for the Key object if "alg" is not set in the
|
|
86
|
-
* JSON Web Key Set
|
|
87
|
-
*
|
|
88
|
-
* @return Key The key object for the JWK
|
|
89
|
-
*
|
|
90
|
-
* @throws InvalidArgumentException Provided JWK is empty
|
|
91
|
-
* @throws UnexpectedValueException Provided JWK was invalid
|
|
92
|
-
* @throws DomainException OpenSSL failure
|
|
93
|
-
*
|
|
94
|
-
* @uses createPemFromModulusAndExponent
|
|
95
|
-
*/
|
|
96
|
-
public static function parseKey(array $jwk, string $defaultAlg = null): ?Key
|
|
97
|
-
{
|
|
98
|
-
if (empty($jwk)) {
|
|
99
|
-
throw new InvalidArgumentException('JWK must not be empty');
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
if (!isset($jwk['kty'])) {
|
|
103
|
-
throw new UnexpectedValueException('JWK must contain a "kty" parameter');
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
if (!isset($jwk['alg'])) {
|
|
107
|
-
if (\is_null($defaultAlg)) {
|
|
108
|
-
// The "alg" parameter is optional in a KTY, but an algorithm is required
|
|
109
|
-
// for parsing in this library. Use the $defaultAlg parameter when parsing the
|
|
110
|
-
// key set in order to prevent this error.
|
|
111
|
-
// @see https://datatracker.ietf.org/doc/html/rfc7517#section-4.4
|
|
112
|
-
throw new UnexpectedValueException('JWK must contain an "alg" parameter');
|
|
113
|
-
}
|
|
114
|
-
$jwk['alg'] = $defaultAlg;
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
switch ($jwk['kty']) {
|
|
118
|
-
case 'RSA':
|
|
119
|
-
if (!empty($jwk['d'])) {
|
|
120
|
-
throw new UnexpectedValueException('RSA private keys are not supported');
|
|
121
|
-
}
|
|
122
|
-
if (!isset($jwk['n']) || !isset($jwk['e'])) {
|
|
123
|
-
throw new UnexpectedValueException('RSA keys must contain values for both "n" and "e"');
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
$pem = self::createPemFromModulusAndExponent($jwk['n'], $jwk['e']);
|
|
127
|
-
$publicKey = \openssl_pkey_get_public($pem);
|
|
128
|
-
if (false === $publicKey) {
|
|
129
|
-
throw new DomainException(
|
|
130
|
-
'OpenSSL error: ' . \openssl_error_string()
|
|
131
|
-
);
|
|
132
|
-
}
|
|
133
|
-
return new Key($publicKey, $jwk['alg']);
|
|
134
|
-
case 'EC':
|
|
135
|
-
if (isset($jwk['d'])) {
|
|
136
|
-
// The key is actually a private key
|
|
137
|
-
throw new UnexpectedValueException('Key data must be for a public key');
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
if (empty($jwk['crv'])) {
|
|
141
|
-
throw new UnexpectedValueException('crv not set');
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
if (!isset(self::EC_CURVES[$jwk['crv']])) {
|
|
145
|
-
throw new DomainException('Unrecognised or unsupported EC curve');
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
if (empty($jwk['x']) || empty($jwk['y'])) {
|
|
149
|
-
throw new UnexpectedValueException('x and y not set');
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
$publicKey = self::createPemFromCrvAndXYCoordinates($jwk['crv'], $jwk['x'], $jwk['y']);
|
|
153
|
-
return new Key($publicKey, $jwk['alg']);
|
|
154
|
-
case 'OKP':
|
|
155
|
-
if (isset($jwk['d'])) {
|
|
156
|
-
// The key is actually a private key
|
|
157
|
-
throw new UnexpectedValueException('Key data must be for a public key');
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
if (!isset($jwk['crv'])) {
|
|
161
|
-
throw new UnexpectedValueException('crv not set');
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
if (empty(self::OKP_SUBTYPES[$jwk['crv']])) {
|
|
165
|
-
throw new DomainException('Unrecognised or unsupported OKP key subtype');
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
if (empty($jwk['x'])) {
|
|
169
|
-
throw new UnexpectedValueException('x not set');
|
|
170
|
-
}
|
|
171
|
-
|
|
172
|
-
// This library works internally with EdDSA keys (Ed25519) encoded in standard base64.
|
|
173
|
-
$publicKey = JWT::convertBase64urlToBase64($jwk['x']);
|
|
174
|
-
return new Key($publicKey, $jwk['alg']);
|
|
175
|
-
default:
|
|
176
|
-
break;
|
|
177
|
-
}
|
|
178
|
-
|
|
179
|
-
return null;
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
/**
|
|
183
|
-
* Converts the EC JWK values to pem format.
|
|
184
|
-
*
|
|
185
|
-
* @param string $crv The EC curve (only P-256 & P-384 is supported)
|
|
186
|
-
* @param string $x The EC x-coordinate
|
|
187
|
-
* @param string $y The EC y-coordinate
|
|
188
|
-
*
|
|
189
|
-
* @return string
|
|
190
|
-
*/
|
|
191
|
-
private static function createPemFromCrvAndXYCoordinates(string $crv, string $x, string $y): string
|
|
192
|
-
{
|
|
193
|
-
$pem =
|
|
194
|
-
self::encodeDER(
|
|
195
|
-
self::ASN1_SEQUENCE,
|
|
196
|
-
self::encodeDER(
|
|
197
|
-
self::ASN1_SEQUENCE,
|
|
198
|
-
self::encodeDER(
|
|
199
|
-
self::ASN1_OBJECT_IDENTIFIER,
|
|
200
|
-
self::encodeOID(self::OID)
|
|
201
|
-
)
|
|
202
|
-
. self::encodeDER(
|
|
203
|
-
self::ASN1_OBJECT_IDENTIFIER,
|
|
204
|
-
self::encodeOID(self::EC_CURVES[$crv])
|
|
205
|
-
)
|
|
206
|
-
) .
|
|
207
|
-
self::encodeDER(
|
|
208
|
-
self::ASN1_BIT_STRING,
|
|
209
|
-
\chr(0x00) . \chr(0x04)
|
|
210
|
-
. JWT::urlsafeB64Decode($x)
|
|
211
|
-
. JWT::urlsafeB64Decode($y)
|
|
212
|
-
)
|
|
213
|
-
);
|
|
214
|
-
|
|
215
|
-
return sprintf(
|
|
216
|
-
"-----BEGIN PUBLIC KEY-----\n%s\n-----END PUBLIC KEY-----\n",
|
|
217
|
-
wordwrap(base64_encode($pem), 64, "\n", true)
|
|
218
|
-
);
|
|
219
|
-
}
|
|
220
|
-
|
|
221
|
-
/**
|
|
222
|
-
* Create a public key represented in PEM format from RSA modulus and exponent information
|
|
223
|
-
*
|
|
224
|
-
* @param string $n The RSA modulus encoded in Base64
|
|
225
|
-
* @param string $e The RSA exponent encoded in Base64
|
|
226
|
-
*
|
|
227
|
-
* @return string The RSA public key represented in PEM format
|
|
228
|
-
*
|
|
229
|
-
* @uses encodeLength
|
|
230
|
-
*/
|
|
231
|
-
private static function createPemFromModulusAndExponent(
|
|
232
|
-
string $n,
|
|
233
|
-
string $e
|
|
234
|
-
): string {
|
|
235
|
-
$mod = JWT::urlsafeB64Decode($n);
|
|
236
|
-
$exp = JWT::urlsafeB64Decode($e);
|
|
237
|
-
|
|
238
|
-
$modulus = \pack('Ca*a*', 2, self::encodeLength(\strlen($mod)), $mod);
|
|
239
|
-
$publicExponent = \pack('Ca*a*', 2, self::encodeLength(\strlen($exp)), $exp);
|
|
240
|
-
|
|
241
|
-
$rsaPublicKey = \pack(
|
|
242
|
-
'Ca*a*a*',
|
|
243
|
-
48,
|
|
244
|
-
self::encodeLength(\strlen($modulus) + \strlen($publicExponent)),
|
|
245
|
-
$modulus,
|
|
246
|
-
$publicExponent
|
|
247
|
-
);
|
|
248
|
-
|
|
249
|
-
// sequence(oid(1.2.840.113549.1.1.1), null)) = rsaEncryption.
|
|
250
|
-
$rsaOID = \pack('H*', '300d06092a864886f70d0101010500'); // hex version of MA0GCSqGSIb3DQEBAQUA
|
|
251
|
-
$rsaPublicKey = \chr(0) . $rsaPublicKey;
|
|
252
|
-
$rsaPublicKey = \chr(3) . self::encodeLength(\strlen($rsaPublicKey)) . $rsaPublicKey;
|
|
253
|
-
|
|
254
|
-
$rsaPublicKey = \pack(
|
|
255
|
-
'Ca*a*',
|
|
256
|
-
48,
|
|
257
|
-
self::encodeLength(\strlen($rsaOID . $rsaPublicKey)),
|
|
258
|
-
$rsaOID . $rsaPublicKey
|
|
259
|
-
);
|
|
260
|
-
|
|
261
|
-
return "-----BEGIN PUBLIC KEY-----\r\n" .
|
|
262
|
-
\chunk_split(\base64_encode($rsaPublicKey), 64) .
|
|
263
|
-
'-----END PUBLIC KEY-----';
|
|
264
|
-
}
|
|
265
|
-
|
|
266
|
-
/**
|
|
267
|
-
* DER-encode the length
|
|
268
|
-
*
|
|
269
|
-
* DER supports lengths up to (2**8)**127, however, we'll only support lengths up to (2**8)**4. See
|
|
270
|
-
* {@link http://itu.int/ITU-T/studygroups/com17/languages/X.690-0207.pdf#p=13 X.690 paragraph 8.1.3} for more information.
|
|
271
|
-
*
|
|
272
|
-
* @param int $length
|
|
273
|
-
* @return string
|
|
274
|
-
*/
|
|
275
|
-
private static function encodeLength(int $length): string
|
|
276
|
-
{
|
|
277
|
-
if ($length <= 0x7F) {
|
|
278
|
-
return \chr($length);
|
|
279
|
-
}
|
|
280
|
-
|
|
281
|
-
$temp = \ltrim(\pack('N', $length), \chr(0));
|
|
282
|
-
|
|
283
|
-
return \pack('Ca*', 0x80 | \strlen($temp), $temp);
|
|
284
|
-
}
|
|
285
|
-
|
|
286
|
-
/**
|
|
287
|
-
* Encodes a value into a DER object.
|
|
288
|
-
* Also defined in Firebase\JWT\JWT
|
|
289
|
-
*
|
|
290
|
-
* @param int $type DER tag
|
|
291
|
-
* @param string $value the value to encode
|
|
292
|
-
* @return string the encoded object
|
|
293
|
-
*/
|
|
294
|
-
private static function encodeDER(int $type, string $value): string
|
|
295
|
-
{
|
|
296
|
-
$tag_header = 0;
|
|
297
|
-
if ($type === self::ASN1_SEQUENCE) {
|
|
298
|
-
$tag_header |= 0x20;
|
|
299
|
-
}
|
|
300
|
-
|
|
301
|
-
// Type
|
|
302
|
-
$der = \chr($tag_header | $type);
|
|
303
|
-
|
|
304
|
-
// Length
|
|
305
|
-
$der .= \chr(\strlen($value));
|
|
306
|
-
|
|
307
|
-
return $der . $value;
|
|
308
|
-
}
|
|
309
|
-
|
|
310
|
-
/**
|
|
311
|
-
* Encodes a string into a DER-encoded OID.
|
|
312
|
-
*
|
|
313
|
-
* @param string $oid the OID string
|
|
314
|
-
* @return string the binary DER-encoded OID
|
|
315
|
-
*/
|
|
316
|
-
private static function encodeOID(string $oid): string
|
|
317
|
-
{
|
|
318
|
-
$octets = explode('.', $oid);
|
|
319
|
-
|
|
320
|
-
// Get the first octet
|
|
321
|
-
$first = (int) array_shift($octets);
|
|
322
|
-
$second = (int) array_shift($octets);
|
|
323
|
-
$oid = \chr($first * 40 + $second);
|
|
324
|
-
|
|
325
|
-
// Iterate over subsequent octets
|
|
326
|
-
foreach ($octets as $octet) {
|
|
327
|
-
if ($octet == 0) {
|
|
328
|
-
$oid .= \chr(0x00);
|
|
329
|
-
continue;
|
|
330
|
-
}
|
|
331
|
-
$bin = '';
|
|
332
|
-
|
|
333
|
-
while ($octet) {
|
|
334
|
-
$bin .= \chr(0x80 | ($octet & 0x7f));
|
|
335
|
-
$octet >>= 7;
|
|
336
|
-
}
|
|
337
|
-
$bin[0] = $bin[0] & \chr(0x7f);
|
|
338
|
-
|
|
339
|
-
// Convert to big endian if necessary
|
|
340
|
-
if (pack('V', 65534) == pack('L', 65534)) {
|
|
341
|
-
$oid .= strrev($bin);
|
|
342
|
-
} else {
|
|
343
|
-
$oid .= $bin;
|
|
344
|
-
}
|
|
345
|
-
}
|
|
346
|
-
|
|
347
|
-
return $oid;
|
|
348
|
-
}
|
|
349
|
-
}
|