create-prisma-php-app 1.0.0
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/LICENSE.txt +9 -0
- package/README.md +158 -0
- package/composer.json +23 -0
- package/composer.lock +812 -0
- package/dist/bootstrap.php +4 -0
- package/dist/index.js +2 -0
- package/dist/node_modules/prisma-client-php/index.enc +1 -0
- package/dist/node_modules/prisma-client-php/index.js +2 -0
- package/dist/node_modules/prisma-client-php/key.enc +1 -0
- package/dist/node_modules/prisma-client-php/package.json +7 -0
- package/dist/prisma/schema.prisma +32 -0
- package/dist/prisma/seed.js +68 -0
- package/dist/public/assets/images/prisma-php.png +0 -0
- package/dist/public/css/styles.css +0 -0
- package/dist/public/css/tailwind.css +3 -0
- package/dist/public/favicon.ico +0 -0
- package/dist/public/index.php +64 -0
- package/dist/settings/paths.php +10 -0
- package/dist/settings/project-settings.js +6 -0
- package/dist/src/app/api/api.php +39 -0
- package/dist/src/app/classes/Validator.php +77 -0
- package/dist/src/app/model/IModel.php +22 -0
- package/package.json +35 -0
- package/tsconfig.json +110 -0
- package/vendor/autoload.php +25 -0
- package/vendor/brick/math/.editorconfig +15 -0
- package/vendor/brick/math/.gitattributes +11 -0
- package/vendor/brick/math/.github/FUNDING.yml +1 -0
- package/vendor/brick/math/.github/workflows/ci.yml +80 -0
- package/vendor/brick/math/CHANGELOG.md +445 -0
- package/vendor/brick/math/LICENSE +20 -0
- package/vendor/brick/math/README.md +247 -0
- package/vendor/brick/math/composer.json +34 -0
- package/vendor/brick/math/phpunit.php +51 -0
- package/vendor/brick/math/phpunit.xml +13 -0
- package/vendor/brick/math/psalm.xml +28 -0
- package/vendor/brick/math/random-tests.php +162 -0
- package/vendor/brick/math/src/BigDecimal.php +786 -0
- package/vendor/brick/math/src/BigInteger.php +1079 -0
- package/vendor/brick/math/src/BigNumber.php +512 -0
- package/vendor/brick/math/src/BigRational.php +445 -0
- package/vendor/brick/math/src/Exception/DivisionByZeroException.php +35 -0
- package/vendor/brick/math/src/Exception/IntegerOverflowException.php +23 -0
- package/vendor/brick/math/src/Exception/MathException.php +12 -0
- package/vendor/brick/math/src/Exception/NegativeNumberException.php +12 -0
- package/vendor/brick/math/src/Exception/NumberFormatException.php +33 -0
- package/vendor/brick/math/src/Exception/RoundingNecessaryException.php +19 -0
- package/vendor/brick/math/src/Internal/Calculator/BcMathCalculator.php +75 -0
- package/vendor/brick/math/src/Internal/Calculator/GmpCalculator.php +108 -0
- package/vendor/brick/math/src/Internal/Calculator/NativeCalculator.php +581 -0
- package/vendor/brick/math/src/Internal/Calculator.php +676 -0
- package/vendor/brick/math/src/RoundingMode.php +107 -0
- package/vendor/brick/math/tests/AbstractTestCase.php +86 -0
- package/vendor/brick/math/tests/BigDecimalTest.php +2596 -0
- package/vendor/brick/math/tests/BigIntegerTest.php +3782 -0
- package/vendor/brick/math/tests/BigNumberTest.php +53 -0
- package/vendor/brick/math/tests/BigRationalTest.php +993 -0
- package/vendor/brick/math/tests/CalculatorDetectTest.php +25 -0
- package/vendor/brick/math/tests/Internal/Calculator/NativeCalculatorTest.php +87 -0
- package/vendor/composer/ClassLoader.php +579 -0
- package/vendor/composer/InstalledVersions.php +359 -0
- package/vendor/composer/LICENSE +21 -0
- package/vendor/composer/autoload_classmap.php +15 -0
- package/vendor/composer/autoload_files.php +13 -0
- package/vendor/composer/autoload_namespaces.php +9 -0
- package/vendor/composer/autoload_psr4.php +20 -0
- package/vendor/composer/autoload_real.php +50 -0
- package/vendor/composer/autoload_static.php +122 -0
- package/vendor/composer/installed.json +825 -0
- package/vendor/composer/installed.php +132 -0
- package/vendor/composer/platform_check.php +26 -0
- package/vendor/firebase/php-jwt/.gitattributes +9 -0
- package/vendor/firebase/php-jwt/.github/release-please.yml +3 -0
- package/vendor/firebase/php-jwt/.github/workflows/tests.yml +57 -0
- package/vendor/firebase/php-jwt/.php-cs-fixer.dist.php +24 -0
- package/vendor/firebase/php-jwt/CHANGELOG.md +170 -0
- package/vendor/firebase/php-jwt/LICENSE +30 -0
- package/vendor/firebase/php-jwt/README.md +424 -0
- package/vendor/firebase/php-jwt/composer.json +42 -0
- package/vendor/firebase/php-jwt/phpstan.neon.dist +5 -0
- package/vendor/firebase/php-jwt/phpunit.xml.dist +18 -0
- package/vendor/firebase/php-jwt/src/BeforeValidException.php +18 -0
- package/vendor/firebase/php-jwt/src/CachedKeySet.php +268 -0
- package/vendor/firebase/php-jwt/src/ExpiredException.php +18 -0
- package/vendor/firebase/php-jwt/src/JWK.php +349 -0
- package/vendor/firebase/php-jwt/src/JWT.php +669 -0
- package/vendor/firebase/php-jwt/src/JWTExceptionWithPayloadInterface.php +20 -0
- package/vendor/firebase/php-jwt/src/Key.php +64 -0
- package/vendor/firebase/php-jwt/src/SignatureInvalidException.php +7 -0
- package/vendor/firebase/php-jwt/tests/CachedKeySetTest.php +598 -0
- package/vendor/firebase/php-jwt/tests/JWKTest.php +172 -0
- package/vendor/firebase/php-jwt/tests/JWTTest.php +543 -0
- package/vendor/firebase/php-jwt/tests/data/ec-jwkset.json +40 -0
- package/vendor/firebase/php-jwt/tests/data/ecdsa-private.pem +18 -0
- package/vendor/firebase/php-jwt/tests/data/ecdsa-public.pem +9 -0
- package/vendor/firebase/php-jwt/tests/data/ecdsa256-private.pem +4 -0
- package/vendor/firebase/php-jwt/tests/data/ecdsa384-private.pem +6 -0
- package/vendor/firebase/php-jwt/tests/data/ecdsa384-public.pem +5 -0
- package/vendor/firebase/php-jwt/tests/data/ed25519-1.pub +1 -0
- package/vendor/firebase/php-jwt/tests/data/ed25519-1.sec +1 -0
- package/vendor/firebase/php-jwt/tests/data/ed25519-jwkset.json +11 -0
- package/vendor/firebase/php-jwt/tests/data/rsa-jwkset.json +18 -0
- package/vendor/firebase/php-jwt/tests/data/rsa-with-passphrase.pem +42 -0
- package/vendor/firebase/php-jwt/tests/data/rsa1-private.pem +27 -0
- package/vendor/firebase/php-jwt/tests/data/rsa1-public.pub +9 -0
- package/vendor/firebase/php-jwt/tests/data/rsa2-private.pem +27 -0
- package/vendor/firebase/php-jwt/tests/data/secp256k1-private.pem +5 -0
- package/vendor/firebase/php-jwt/tests/data/secp256k1-public.pem +4 -0
- package/vendor/graham-campbell/result-type/.gitattributes +9 -0
- package/vendor/graham-campbell/result-type/.github/CODE_OF_CONDUCT.md +132 -0
- package/vendor/graham-campbell/result-type/.github/CONTRIBUTING.md +31 -0
- package/vendor/graham-campbell/result-type/.github/FUNDING.yml +2 -0
- package/vendor/graham-campbell/result-type/.github/SECURITY.md +14 -0
- package/vendor/graham-campbell/result-type/.github/workflows/tests.yml +40 -0
- package/vendor/graham-campbell/result-type/CHANGELOG.md +43 -0
- package/vendor/graham-campbell/result-type/LICENSE +21 -0
- package/vendor/graham-campbell/result-type/README.md +42 -0
- package/vendor/graham-campbell/result-type/composer.json +33 -0
- package/vendor/graham-campbell/result-type/phpunit.xml.dist +13 -0
- package/vendor/graham-campbell/result-type/src/Error.php +121 -0
- package/vendor/graham-campbell/result-type/src/Result.php +69 -0
- package/vendor/graham-campbell/result-type/src/Success.php +120 -0
- package/vendor/graham-campbell/result-type/tests/ResultTest.php +95 -0
- package/vendor/hidehalo/nanoid-php/.editorconfig +15 -0
- package/vendor/hidehalo/nanoid-php/.gitattributes +8 -0
- package/vendor/hidehalo/nanoid-php/.github/workflows/php.yml +49 -0
- package/vendor/hidehalo/nanoid-php/.styleci.yml +1 -0
- package/vendor/hidehalo/nanoid-php/CHANGELOG.md +36 -0
- package/vendor/hidehalo/nanoid-php/CODE_OF_CONDUCT.md +74 -0
- package/vendor/hidehalo/nanoid-php/CONTRIBUTING.md +32 -0
- package/vendor/hidehalo/nanoid-php/ISSUE_TEMPLATE.md +27 -0
- package/vendor/hidehalo/nanoid-php/LICENSE.md +21 -0
- package/vendor/hidehalo/nanoid-php/PULL_REQUEST_TEMPLATE.md +43 -0
- package/vendor/hidehalo/nanoid-php/README.md +108 -0
- package/vendor/hidehalo/nanoid-php/benchmark/benchmark.php +24 -0
- package/vendor/hidehalo/nanoid-php/composer.json +62 -0
- package/vendor/hidehalo/nanoid-php/examples/basic_usage.php +24 -0
- package/vendor/hidehalo/nanoid-php/examples/custom_formated.php +29 -0
- package/vendor/hidehalo/nanoid-php/phpunit.xml +31 -0
- package/vendor/hidehalo/nanoid-php/src/Client.php +120 -0
- package/vendor/hidehalo/nanoid-php/src/Core.php +31 -0
- package/vendor/hidehalo/nanoid-php/src/CoreInterface.php +19 -0
- package/vendor/hidehalo/nanoid-php/src/Generator.php +13 -0
- package/vendor/hidehalo/nanoid-php/src/GeneratorInterface.php +13 -0
- package/vendor/hidehalo/nanoid-php/tests/ClientTest.php +76 -0
- package/vendor/hidehalo/nanoid-php/tests/CoreTest.php +37 -0
- package/vendor/hidehalo/nanoid-php/tests/GeneratorTest.php +34 -0
- package/vendor/hidehalo/nanoid-php/tests/Support/DummyGenerator.php +20 -0
- package/vendor/paragonie/random_compat/.gitattributes +14 -0
- package/vendor/paragonie/random_compat/.scrutinizer.yml +4 -0
- package/vendor/paragonie/random_compat/.travis.yml +59 -0
- package/vendor/paragonie/random_compat/CHANGELOG.md +3 -0
- package/vendor/paragonie/random_compat/LICENSE +22 -0
- package/vendor/paragonie/random_compat/RATIONALE.md +36 -0
- package/vendor/paragonie/random_compat/README.md +232 -0
- package/vendor/paragonie/random_compat/SECURITY.md +108 -0
- package/vendor/paragonie/random_compat/build-phar.sh +5 -0
- package/vendor/paragonie/random_compat/composer.json +34 -0
- package/vendor/paragonie/random_compat/dist/random_compat.phar.pubkey +5 -0
- package/vendor/paragonie/random_compat/dist/random_compat.phar.pubkey.asc +11 -0
- package/vendor/paragonie/random_compat/lib/random.php +32 -0
- package/vendor/paragonie/random_compat/other/build_phar.php +57 -0
- package/vendor/paragonie/random_compat/other/ide_stubs/COM.php +20 -0
- package/vendor/paragonie/random_compat/other/ide_stubs/README.md +7 -0
- package/vendor/paragonie/random_compat/other/ide_stubs/com_exception.php +11 -0
- package/vendor/paragonie/random_compat/other/ide_stubs/libsodium.php +90 -0
- package/vendor/paragonie/random_compat/phpunit.sh +60 -0
- package/vendor/paragonie/random_compat/phpunit.xml.dist +31 -0
- package/vendor/paragonie/random_compat/psalm-autoload.php +9 -0
- package/vendor/paragonie/random_compat/psalm.xml +19 -0
- package/vendor/paragonie/random_compat/tests/full/DieHardTest.php +61 -0
- package/vendor/paragonie/random_compat/tests/full/StatTest.php +52 -0
- package/vendor/paragonie/random_compat/tests/specific/capicom.php +7 -0
- package/vendor/paragonie/random_compat/tests/specific/dev_urandom.php +7 -0
- package/vendor/paragonie/random_compat/tests/specific/libsodium.php +7 -0
- package/vendor/paragonie/random_compat/tests/specific/libsodium_legacy.php +7 -0
- package/vendor/paragonie/random_compat/tests/specific/mcrypt.php +7 -0
- package/vendor/paragonie/random_compat/tests/unit/RandomBytesTest.php +80 -0
- package/vendor/paragonie/random_compat/tests/unit/RandomIntTest.php +63 -0
- package/vendor/paragonie/random_compat/tests/unit/UtilityTest.php +95 -0
- package/vendor/paragonie/random_compat/tests/unit_with_basedir/RandomBytesTest.php +100 -0
- package/vendor/paragonie/random_compat/tests/unit_with_basedir/RandomIntTest.php +82 -0
- package/vendor/paragonie/random_compat/tests/unit_with_basedir/UtilityTest.php +95 -0
- package/vendor/phpoption/phpoption/.gitattributes +14 -0
- package/vendor/phpoption/phpoption/.github/CODE_OF_CONDUCT.md +132 -0
- package/vendor/phpoption/phpoption/.github/CONTRIBUTING.md +30 -0
- package/vendor/phpoption/phpoption/.github/FUNDING.yml +2 -0
- package/vendor/phpoption/phpoption/.github/SECURITY.md +14 -0
- package/vendor/phpoption/phpoption/.github/workflows/static.yml +74 -0
- package/vendor/phpoption/phpoption/.github/workflows/tests.yml +40 -0
- package/vendor/phpoption/phpoption/LICENSE +201 -0
- package/vendor/phpoption/phpoption/Makefile +26 -0
- package/vendor/phpoption/phpoption/README.md +194 -0
- package/vendor/phpoption/phpoption/composer.json +52 -0
- package/vendor/phpoption/phpoption/phpstan-baseline.neon +32 -0
- package/vendor/phpoption/phpoption/phpstan.neon.dist +8 -0
- package/vendor/phpoption/phpoption/phpunit.xml.dist +13 -0
- package/vendor/phpoption/phpoption/psalm.xml +12 -0
- package/vendor/phpoption/phpoption/src/PhpOption/LazyOption.php +175 -0
- package/vendor/phpoption/phpoption/src/PhpOption/None.php +136 -0
- package/vendor/phpoption/phpoption/src/PhpOption/Option.php +434 -0
- package/vendor/phpoption/phpoption/src/PhpOption/Some.php +169 -0
- package/vendor/phpoption/phpoption/tests/PhpOption/Tests/EnsureTest.php +77 -0
- package/vendor/phpoption/phpoption/tests/PhpOption/Tests/LazyOptionTest.php +200 -0
- package/vendor/phpoption/phpoption/tests/PhpOption/Tests/NoneTest.php +153 -0
- package/vendor/phpoption/phpoption/tests/PhpOption/Tests/OptionTest.php +160 -0
- package/vendor/phpoption/phpoption/tests/PhpOption/Tests/SomeTest.php +194 -0
- package/vendor/phpoption/phpoption/tests/bootstrap.php +8 -0
- package/vendor/phpoption/phpoption/vendor-bin/phpstan/composer.json +8 -0
- package/vendor/phpoption/phpoption/vendor-bin/psalm/composer.json +8 -0
- package/vendor/ramsey/uuid/.editorconfig +16 -0
- package/vendor/ramsey/uuid/.gitattributes +26 -0
- package/vendor/ramsey/uuid/.github/CODEOWNERS +1 -0
- package/vendor/ramsey/uuid/.github/FUNDING.yml +2 -0
- package/vendor/ramsey/uuid/.github/ISSUE_TEMPLATE/Bug_Report.md +35 -0
- package/vendor/ramsey/uuid/.github/ISSUE_TEMPLATE/Feature_Request.md +31 -0
- package/vendor/ramsey/uuid/.github/ISSUE_TEMPLATE/Question.md +19 -0
- package/vendor/ramsey/uuid/.github/ISSUE_TEMPLATE/config.yml +1 -0
- package/vendor/ramsey/uuid/.github/dependabot.yml +15 -0
- package/vendor/ramsey/uuid/.github/pull_request_template.md +27 -0
- package/vendor/ramsey/uuid/.github/workflows/continuous-integration.yml +181 -0
- package/vendor/ramsey/uuid/.github/workflows/merge-dependabot-upgrades.yml +24 -0
- package/vendor/ramsey/uuid/.readthedocs.yml +11 -0
- package/vendor/ramsey/uuid/CHANGELOG.md +1511 -0
- package/vendor/ramsey/uuid/CODE_OF_CONDUCT.md +73 -0
- package/vendor/ramsey/uuid/CONTRIBUTING.md +171 -0
- package/vendor/ramsey/uuid/LICENSE +19 -0
- package/vendor/ramsey/uuid/README.md +83 -0
- package/vendor/ramsey/uuid/SECURITY.md +170 -0
- package/vendor/ramsey/uuid/build/.gitignore +6 -0
- package/vendor/ramsey/uuid/build/cache/.gitkeep +0 -0
- package/vendor/ramsey/uuid/build/logs/.gitkeep +0 -0
- package/vendor/ramsey/uuid/captainhook.json +105 -0
- package/vendor/ramsey/uuid/codecov.yml +29 -0
- package/vendor/ramsey/uuid/composer.json +106 -0
- package/vendor/ramsey/uuid/composer.lock +7208 -0
- package/vendor/ramsey/uuid/docs/Makefile +20 -0
- package/vendor/ramsey/uuid/docs/README.md +36 -0
- package/vendor/ramsey/uuid/docs/_static/.gitkeep +0 -0
- package/vendor/ramsey/uuid/docs/conf.py +103 -0
- package/vendor/ramsey/uuid/docs/copyright.rst +18 -0
- package/vendor/ramsey/uuid/docs/customize/calculators.rst +75 -0
- package/vendor/ramsey/uuid/docs/customize/factory.rst +93 -0
- package/vendor/ramsey/uuid/docs/customize/ordered-time-codec.rst +86 -0
- package/vendor/ramsey/uuid/docs/customize/timestamp-first-comb-codec.rst +72 -0
- package/vendor/ramsey/uuid/docs/customize/validators.rst +39 -0
- package/vendor/ramsey/uuid/docs/customize.rst +56 -0
- package/vendor/ramsey/uuid/docs/database.rst +260 -0
- package/vendor/ramsey/uuid/docs/faq.rst +132 -0
- package/vendor/ramsey/uuid/docs/index.rst +51 -0
- package/vendor/ramsey/uuid/docs/introduction.rst +31 -0
- package/vendor/ramsey/uuid/docs/nonstandard/guid.rst +152 -0
- package/vendor/ramsey/uuid/docs/nonstandard/other.rst +49 -0
- package/vendor/ramsey/uuid/docs/nonstandard/version6.rst +17 -0
- package/vendor/ramsey/uuid/docs/nonstandard.rst +40 -0
- package/vendor/ramsey/uuid/docs/quickstart.rst +112 -0
- package/vendor/ramsey/uuid/docs/reference/calculators.rst +168 -0
- package/vendor/ramsey/uuid/docs/reference/exceptions.rst +92 -0
- package/vendor/ramsey/uuid/docs/reference/fields-fieldsinterface.rst +16 -0
- package/vendor/ramsey/uuid/docs/reference/guid-fields.rst +13 -0
- package/vendor/ramsey/uuid/docs/reference/guid-guid.rst +20 -0
- package/vendor/ramsey/uuid/docs/reference/helper.rst +62 -0
- package/vendor/ramsey/uuid/docs/reference/name-based-namespaces.rst +31 -0
- package/vendor/ramsey/uuid/docs/reference/nonstandard-fields.rst +13 -0
- package/vendor/ramsey/uuid/docs/reference/nonstandard-uuid.rst +20 -0
- package/vendor/ramsey/uuid/docs/reference/nonstandard-uuidv6.rst +34 -0
- package/vendor/ramsey/uuid/docs/reference/rfc4122-fieldsinterface.rst +78 -0
- package/vendor/ramsey/uuid/docs/reference/rfc4122-uuidinterface.rst +20 -0
- package/vendor/ramsey/uuid/docs/reference/rfc4122-uuidv1.rst +21 -0
- package/vendor/ramsey/uuid/docs/reference/rfc4122-uuidv2.rst +47 -0
- package/vendor/ramsey/uuid/docs/reference/rfc4122-uuidv3.rst +13 -0
- package/vendor/ramsey/uuid/docs/reference/rfc4122-uuidv4.rst +13 -0
- package/vendor/ramsey/uuid/docs/reference/rfc4122-uuidv5.rst +13 -0
- package/vendor/ramsey/uuid/docs/reference/rfc4122-uuidv6.rst +31 -0
- package/vendor/ramsey/uuid/docs/reference/rfc4122-uuidv7.rst +20 -0
- package/vendor/ramsey/uuid/docs/reference/rfc4122-uuidv8.rst +13 -0
- package/vendor/ramsey/uuid/docs/reference/rfc4122-version.rst +87 -0
- package/vendor/ramsey/uuid/docs/reference/timebaseduuidinterface.rst +16 -0
- package/vendor/ramsey/uuid/docs/reference/types.rst +79 -0
- package/vendor/ramsey/uuid/docs/reference/uuid.rst +161 -0
- package/vendor/ramsey/uuid/docs/reference/uuidfactoryinterface.rst +102 -0
- package/vendor/ramsey/uuid/docs/reference/uuidinterface.rst +60 -0
- package/vendor/ramsey/uuid/docs/reference/validators.rst +34 -0
- package/vendor/ramsey/uuid/docs/reference/variant.rst +32 -0
- package/vendor/ramsey/uuid/docs/reference.rst +37 -0
- package/vendor/ramsey/uuid/docs/requirements.txt +3 -0
- package/vendor/ramsey/uuid/docs/rfc4122/version1.rst +192 -0
- package/vendor/ramsey/uuid/docs/rfc4122/version2.rst +273 -0
- package/vendor/ramsey/uuid/docs/rfc4122/version3.rst +68 -0
- package/vendor/ramsey/uuid/docs/rfc4122/version4.rst +39 -0
- package/vendor/ramsey/uuid/docs/rfc4122/version5.rst +108 -0
- package/vendor/ramsey/uuid/docs/rfc4122/version6.rst +213 -0
- package/vendor/ramsey/uuid/docs/rfc4122/version7.rst +173 -0
- package/vendor/ramsey/uuid/docs/rfc4122/version8.rst +51 -0
- package/vendor/ramsey/uuid/docs/rfc4122.rst +67 -0
- package/vendor/ramsey/uuid/docs/testing.rst +199 -0
- package/vendor/ramsey/uuid/docs/tidelift.rst +74 -0
- package/vendor/ramsey/uuid/docs/upgrading/2-to-3.rst +31 -0
- package/vendor/ramsey/uuid/docs/upgrading/3-to-4.rst +512 -0
- package/vendor/ramsey/uuid/docs/upgrading.rst +11 -0
- package/vendor/ramsey/uuid/phpbench.json +10 -0
- package/vendor/ramsey/uuid/phpcs.xml.dist +476 -0
- package/vendor/ramsey/uuid/phpstan-tests.neon +32 -0
- package/vendor/ramsey/uuid/phpstan.neon.dist +25 -0
- package/vendor/ramsey/uuid/phpunit.xml.dist +26 -0
- package/vendor/ramsey/uuid/psalm-baseline.xml +133 -0
- package/vendor/ramsey/uuid/psalm.xml +25 -0
- package/vendor/ramsey/uuid/resources/vagrant/README.md +10 -0
- package/vendor/ramsey/uuid/resources/vagrant/freebsd/README.md +15 -0
- package/vendor/ramsey/uuid/resources/vagrant/freebsd/Vagrantfile +35 -0
- package/vendor/ramsey/uuid/resources/vagrant/linux/README.md +15 -0
- package/vendor/ramsey/uuid/resources/vagrant/linux/Vagrantfile +27 -0
- package/vendor/ramsey/uuid/resources/vagrant/windows/README.md +16 -0
- package/vendor/ramsey/uuid/resources/vagrant/windows/Vagrantfile +22 -0
- package/vendor/ramsey/uuid/src/BinaryUtils.php +106 -0
- package/vendor/ramsey/uuid/src/Builder/FallbackBuilder.php +68 -0
- package/vendor/ramsey/uuid/src/Builder/UuidBuilderInterface.php +39 -0
- package/vendor/ramsey/uuid/src/Codec/CodecInterface.php +67 -0
- package/vendor/ramsey/uuid/src/Codec/GuidStringCodec.php +82 -0
- package/vendor/ramsey/uuid/src/Codec/OrderedTimeCodec.php +114 -0
- package/vendor/ramsey/uuid/src/Codec/StringCodec.php +128 -0
- package/vendor/ramsey/uuid/src/Codec/TimestampFirstCombCodec.php +105 -0
- package/vendor/ramsey/uuid/src/Codec/TimestampLastCombCodec.php +51 -0
- package/vendor/ramsey/uuid/src/Converter/Number/GenericNumberConverter.php +48 -0
- package/vendor/ramsey/uuid/src/Converter/NumberConverterInterface.php +53 -0
- package/vendor/ramsey/uuid/src/Converter/Time/GenericTimeConverter.php +118 -0
- package/vendor/ramsey/uuid/src/Converter/Time/PhpTimeConverter.php +163 -0
- package/vendor/ramsey/uuid/src/Converter/Time/UnixTimeConverter.php +90 -0
- package/vendor/ramsey/uuid/src/Converter/TimeConverterInterface.php +58 -0
- package/vendor/ramsey/uuid/src/Exception/BuilderNotFoundException.php +24 -0
- package/vendor/ramsey/uuid/src/Exception/DateTimeException.php +24 -0
- package/vendor/ramsey/uuid/src/Exception/DceSecurityException.php +25 -0
- package/vendor/ramsey/uuid/src/Exception/InvalidArgumentException.php +24 -0
- package/vendor/ramsey/uuid/src/Exception/InvalidBytesException.php +24 -0
- package/vendor/ramsey/uuid/src/Exception/InvalidUuidStringException.php +25 -0
- package/vendor/ramsey/uuid/src/Exception/NameException.php +25 -0
- package/vendor/ramsey/uuid/src/Exception/NodeException.php +24 -0
- package/vendor/ramsey/uuid/src/Exception/RandomSourceException.php +27 -0
- package/vendor/ramsey/uuid/src/Exception/TimeSourceException.php +24 -0
- package/vendor/ramsey/uuid/src/Exception/UnableToBuildUuidException.php +24 -0
- package/vendor/ramsey/uuid/src/Exception/UnsupportedOperationException.php +24 -0
- package/vendor/ramsey/uuid/src/Exception/UuidExceptionInterface.php +21 -0
- package/vendor/ramsey/uuid/src/FeatureSet.php +395 -0
- package/vendor/ramsey/uuid/src/Fields/FieldsInterface.php +42 -0
- package/vendor/ramsey/uuid/src/Fields/SerializableFieldsTrait.php +70 -0
- package/vendor/ramsey/uuid/src/Generator/CombGenerator.php +124 -0
- package/vendor/ramsey/uuid/src/Generator/DceSecurityGenerator.php +139 -0
- package/vendor/ramsey/uuid/src/Generator/DceSecurityGeneratorInterface.php +53 -0
- package/vendor/ramsey/uuid/src/Generator/DefaultNameGenerator.php +51 -0
- package/vendor/ramsey/uuid/src/Generator/DefaultTimeGenerator.php +131 -0
- package/vendor/ramsey/uuid/src/Generator/NameGeneratorFactory.php +30 -0
- package/vendor/ramsey/uuid/src/Generator/NameGeneratorInterface.php +38 -0
- package/vendor/ramsey/uuid/src/Generator/PeclUuidNameGenerator.php +52 -0
- package/vendor/ramsey/uuid/src/Generator/PeclUuidRandomGenerator.php +37 -0
- package/vendor/ramsey/uuid/src/Generator/PeclUuidTimeGenerator.php +39 -0
- package/vendor/ramsey/uuid/src/Generator/RandomBytesGenerator.php +45 -0
- package/vendor/ramsey/uuid/src/Generator/RandomGeneratorFactory.php +30 -0
- package/vendor/ramsey/uuid/src/Generator/RandomGeneratorInterface.php +31 -0
- package/vendor/ramsey/uuid/src/Generator/TimeGeneratorFactory.php +45 -0
- package/vendor/ramsey/uuid/src/Generator/TimeGeneratorInterface.php +38 -0
- package/vendor/ramsey/uuid/src/Generator/UnixTimeGenerator.php +170 -0
- package/vendor/ramsey/uuid/src/Guid/Fields.php +208 -0
- package/vendor/ramsey/uuid/src/Guid/Guid.php +61 -0
- package/vendor/ramsey/uuid/src/Guid/GuidBuilder.php +79 -0
- package/vendor/ramsey/uuid/src/Lazy/LazyUuidFromString.php +226 -0
- package/vendor/ramsey/uuid/src/Math/BrickMathCalculator.php +145 -0
- package/vendor/ramsey/uuid/src/Math/CalculatorInterface.php +106 -0
- package/vendor/ramsey/uuid/src/Math/RoundingMode.php +146 -0
- package/vendor/ramsey/uuid/src/Nonstandard/Fields.php +154 -0
- package/vendor/ramsey/uuid/src/Nonstandard/Uuid.php +37 -0
- package/vendor/ramsey/uuid/src/Nonstandard/UuidBuilder.php +78 -0
- package/vendor/ramsey/uuid/src/Nonstandard/UuidV6.php +113 -0
- package/vendor/ramsey/uuid/src/Provider/Dce/SystemDceSecurityProvider.php +236 -0
- package/vendor/ramsey/uuid/src/Provider/DceSecurityProviderInterface.php +41 -0
- package/vendor/ramsey/uuid/src/Provider/Node/FallbackNodeProvider.php +54 -0
- package/vendor/ramsey/uuid/src/Provider/Node/RandomNodeProvider.php +69 -0
- package/vendor/ramsey/uuid/src/Provider/Node/StaticNodeProvider.php +74 -0
- package/vendor/ramsey/uuid/src/Provider/Node/SystemNodeProvider.php +190 -0
- package/vendor/ramsey/uuid/src/Provider/NodeProviderInterface.php +30 -0
- package/vendor/ramsey/uuid/src/Provider/Time/FixedTimeProvider.php +57 -0
- package/vendor/ramsey/uuid/src/Provider/Time/SystemTimeProvider.php +33 -0
- package/vendor/ramsey/uuid/src/Provider/TimeProviderInterface.php +28 -0
- package/vendor/ramsey/uuid/src/Rfc4122/Fields.php +214 -0
- package/vendor/ramsey/uuid/src/Rfc4122/FieldsInterface.php +129 -0
- package/vendor/ramsey/uuid/src/Rfc4122/MaxTrait.php +41 -0
- package/vendor/ramsey/uuid/src/Rfc4122/MaxUuid.php +27 -0
- package/vendor/ramsey/uuid/src/Rfc4122/NilTrait.php +41 -0
- package/vendor/ramsey/uuid/src/Rfc4122/NilUuid.php +27 -0
- package/vendor/ramsey/uuid/src/Rfc4122/TimeTrait.php +55 -0
- package/vendor/ramsey/uuid/src/Rfc4122/UuidBuilder.php +116 -0
- package/vendor/ramsey/uuid/src/Rfc4122/UuidInterface.php +30 -0
- package/vendor/ramsey/uuid/src/Rfc4122/UuidV1.php +61 -0
- package/vendor/ramsey/uuid/src/Rfc4122/UuidV2.php +119 -0
- package/vendor/ramsey/uuid/src/Rfc4122/UuidV3.php +58 -0
- package/vendor/ramsey/uuid/src/Rfc4122/UuidV4.php +58 -0
- package/vendor/ramsey/uuid/src/Rfc4122/UuidV5.php +58 -0
- package/vendor/ramsey/uuid/src/Rfc4122/UuidV6.php +30 -0
- package/vendor/ramsey/uuid/src/Rfc4122/UuidV7.php +63 -0
- package/vendor/ramsey/uuid/src/Rfc4122/UuidV8.php +65 -0
- package/vendor/ramsey/uuid/src/Rfc4122/Validator.php +45 -0
- package/vendor/ramsey/uuid/src/Rfc4122/VariantTrait.php +87 -0
- package/vendor/ramsey/uuid/src/Rfc4122/Version.php +139 -0
- package/vendor/ramsey/uuid/src/Rfc4122/VersionTrait.php +57 -0
- package/vendor/ramsey/uuid/src/TimeBasedUuidFactoryInterface.php +48 -0
- package/vendor/ramsey/uuid/src/TimeBasedUuidInterface.php +30 -0
- package/vendor/ramsey/uuid/src/Type/Decimal.php +135 -0
- package/vendor/ramsey/uuid/src/Type/Hexadecimal.php +109 -0
- package/vendor/ramsey/uuid/src/Type/Integer.php +145 -0
- package/vendor/ramsey/uuid/src/Type/NumberInterface.php +28 -0
- package/vendor/ramsey/uuid/src/Type/Time.php +108 -0
- package/vendor/ramsey/uuid/src/Type/TypeInterface.php +45 -0
- package/vendor/ramsey/uuid/src/Uuid.php +645 -0
- package/vendor/ramsey/uuid/src/UuidFactory.php +503 -0
- package/vendor/ramsey/uuid/src/UuidFactoryInterface.php +184 -0
- package/vendor/ramsey/uuid/src/UuidInterface.php +114 -0
- package/vendor/ramsey/uuid/src/Validator/GenericValidator.php +45 -0
- package/vendor/ramsey/uuid/src/Validator/ValidatorInterface.php +39 -0
- package/vendor/ramsey/uuid/src/Variant.php +60 -0
- package/vendor/ramsey/uuid/src/functions.php +160 -0
- package/vendor/ramsey/uuid/tests/BinaryUtilsTest.php +381 -0
- package/vendor/ramsey/uuid/tests/Builder/FallbackBuilderTest.php +198 -0
- package/vendor/ramsey/uuid/tests/Codec/GuidStringCodecTest.php +118 -0
- package/vendor/ramsey/uuid/tests/Codec/OrderedTimeCodecTest.php +258 -0
- package/vendor/ramsey/uuid/tests/Codec/StringCodecTest.php +149 -0
- package/vendor/ramsey/uuid/tests/Converter/Number/GenericNumberConverterTest.php +28 -0
- package/vendor/ramsey/uuid/tests/Converter/Time/GenericTimeConverterTest.php +147 -0
- package/vendor/ramsey/uuid/tests/Converter/Time/PhpTimeConverterTest.php +199 -0
- package/vendor/ramsey/uuid/tests/Converter/Time/UnixTimeConverterTest.php +202 -0
- package/vendor/ramsey/uuid/tests/Encoder/TimestampFirstCombCodecTest.php +105 -0
- package/vendor/ramsey/uuid/tests/Encoder/TimestampLastCombCodecTest.php +106 -0
- package/vendor/ramsey/uuid/tests/ExpectedBehaviorTest.php +573 -0
- package/vendor/ramsey/uuid/tests/FeatureSetTest.php +88 -0
- package/vendor/ramsey/uuid/tests/FunctionsTest.php +151 -0
- package/vendor/ramsey/uuid/tests/Generator/CombGeneratorTest.php +134 -0
- package/vendor/ramsey/uuid/tests/Generator/DceSecurityGeneratorTest.php +282 -0
- package/vendor/ramsey/uuid/tests/Generator/DefaultNameGeneratorTest.php +83 -0
- package/vendor/ramsey/uuid/tests/Generator/DefaultTimeGeneratorTest.php +202 -0
- package/vendor/ramsey/uuid/tests/Generator/NameGeneratorFactoryTest.php +19 -0
- package/vendor/ramsey/uuid/tests/Generator/PeclUuidNameGeneratorTest.php +107 -0
- package/vendor/ramsey/uuid/tests/Generator/PeclUuidRandomGeneratorTest.php +30 -0
- package/vendor/ramsey/uuid/tests/Generator/PeclUuidTimeGeneratorTest.php +30 -0
- package/vendor/ramsey/uuid/tests/Generator/RandomBytesGeneratorTest.php +70 -0
- package/vendor/ramsey/uuid/tests/Generator/RandomGeneratorFactoryTest.php +19 -0
- package/vendor/ramsey/uuid/tests/Generator/TimeGeneratorFactoryTest.php +33 -0
- package/vendor/ramsey/uuid/tests/Generator/UnixTimeGeneratorTest.php +204 -0
- package/vendor/ramsey/uuid/tests/Guid/FieldsTest.php +235 -0
- package/vendor/ramsey/uuid/tests/Guid/GuidBuilderTest.php +33 -0
- package/vendor/ramsey/uuid/tests/Math/BrickMathCalculatorTest.php +116 -0
- package/vendor/ramsey/uuid/tests/Nonstandard/FieldsTest.php +84 -0
- package/vendor/ramsey/uuid/tests/Nonstandard/UuidBuilderTest.php +33 -0
- package/vendor/ramsey/uuid/tests/Nonstandard/UuidV6Test.php +192 -0
- package/vendor/ramsey/uuid/tests/Provider/Dce/SystemDceSecurityProviderTest.php +505 -0
- package/vendor/ramsey/uuid/tests/Provider/Node/FallbackNodeProviderTest.php +87 -0
- package/vendor/ramsey/uuid/tests/Provider/Node/RandomNodeProviderTest.php +124 -0
- package/vendor/ramsey/uuid/tests/Provider/Node/StaticNodeProviderTest.php +58 -0
- package/vendor/ramsey/uuid/tests/Provider/Node/SystemNodeProviderTest.php +950 -0
- package/vendor/ramsey/uuid/tests/Provider/Time/FixedTimeProviderTest.php +41 -0
- package/vendor/ramsey/uuid/tests/Provider/Time/SystemTimeProviderTest.php +20 -0
- package/vendor/ramsey/uuid/tests/Rfc4122/FieldsTest.php +260 -0
- package/vendor/ramsey/uuid/tests/Rfc4122/UuidBuilderTest.php +145 -0
- package/vendor/ramsey/uuid/tests/Rfc4122/UuidV1Test.php +123 -0
- package/vendor/ramsey/uuid/tests/Rfc4122/UuidV2Test.php +214 -0
- package/vendor/ramsey/uuid/tests/Rfc4122/UuidV3Test.php +56 -0
- package/vendor/ramsey/uuid/tests/Rfc4122/UuidV4Test.php +56 -0
- package/vendor/ramsey/uuid/tests/Rfc4122/UuidV5Test.php +56 -0
- package/vendor/ramsey/uuid/tests/Rfc4122/UuidV6Test.php +221 -0
- package/vendor/ramsey/uuid/tests/Rfc4122/UuidV7Test.php +131 -0
- package/vendor/ramsey/uuid/tests/Rfc4122/UuidV8Test.php +56 -0
- package/vendor/ramsey/uuid/tests/Rfc4122/ValidatorTest.php +122 -0
- package/vendor/ramsey/uuid/tests/Rfc4122/VariantTraitTest.php +109 -0
- package/vendor/ramsey/uuid/tests/TestCase.php +29 -0
- package/vendor/ramsey/uuid/tests/Type/DecimalTest.php +305 -0
- package/vendor/ramsey/uuid/tests/Type/HexadecimalTest.php +112 -0
- package/vendor/ramsey/uuid/tests/Type/IntegerTest.php +235 -0
- package/vendor/ramsey/uuid/tests/Type/TimeTest.php +120 -0
- package/vendor/ramsey/uuid/tests/UuidFactoryTest.php +233 -0
- package/vendor/ramsey/uuid/tests/UuidTest.php +1910 -0
- package/vendor/ramsey/uuid/tests/Validator/GenericValidatorTest.php +98 -0
- package/vendor/ramsey/uuid/tests/benchmark/GuidConversionBench.php +43 -0
- package/vendor/ramsey/uuid/tests/benchmark/NonLazyUuidConversionBench.php +39 -0
- package/vendor/ramsey/uuid/tests/benchmark/UuidFieldExtractionBench.php +86 -0
- package/vendor/ramsey/uuid/tests/benchmark/UuidGenerationBench.php +113 -0
- package/vendor/ramsey/uuid/tests/benchmark/UuidSerializationBench.php +206 -0
- package/vendor/ramsey/uuid/tests/benchmark/UuidStringConversionBench.php +257 -0
- package/vendor/ramsey/uuid/tests/bootstrap.php +12 -0
- package/vendor/ramsey/uuid/tests/static-analysis/UuidIsImmutable.php +96 -0
- package/vendor/ramsey/uuid/tests/static-analysis/UuidIsNeverEmpty.php +36 -0
- package/vendor/ramsey/uuid/tests/static-analysis/ValidUuidIsNonEmpty.php +44 -0
- package/vendor/ramsey/uuid/tests/static-analysis/stubs.php +33 -0
- package/vendor/symfony/polyfill-ctype/Ctype.php +232 -0
- package/vendor/symfony/polyfill-ctype/LICENSE +19 -0
- package/vendor/symfony/polyfill-ctype/README.md +12 -0
- package/vendor/symfony/polyfill-ctype/bootstrap.php +50 -0
- package/vendor/symfony/polyfill-ctype/bootstrap80.php +46 -0
- package/vendor/symfony/polyfill-ctype/composer.json +41 -0
- package/vendor/symfony/polyfill-mbstring/LICENSE +19 -0
- package/vendor/symfony/polyfill-mbstring/Mbstring.php +947 -0
- package/vendor/symfony/polyfill-mbstring/README.md +13 -0
- package/vendor/symfony/polyfill-mbstring/Resources/unidata/caseFolding.php +119 -0
- package/vendor/symfony/polyfill-mbstring/Resources/unidata/lowerCase.php +1397 -0
- package/vendor/symfony/polyfill-mbstring/Resources/unidata/titleCaseRegexp.php +5 -0
- package/vendor/symfony/polyfill-mbstring/Resources/unidata/upperCase.php +1489 -0
- package/vendor/symfony/polyfill-mbstring/bootstrap.php +151 -0
- package/vendor/symfony/polyfill-mbstring/bootstrap80.php +147 -0
- package/vendor/symfony/polyfill-mbstring/composer.json +41 -0
- package/vendor/symfony/polyfill-php80/LICENSE +19 -0
- package/vendor/symfony/polyfill-php80/Php80.php +115 -0
- package/vendor/symfony/polyfill-php80/PhpToken.php +103 -0
- package/vendor/symfony/polyfill-php80/README.md +25 -0
- package/vendor/symfony/polyfill-php80/Resources/stubs/Attribute.php +31 -0
- package/vendor/symfony/polyfill-php80/Resources/stubs/PhpToken.php +16 -0
- package/vendor/symfony/polyfill-php80/Resources/stubs/Stringable.php +20 -0
- package/vendor/symfony/polyfill-php80/Resources/stubs/UnhandledMatchError.php +16 -0
- package/vendor/symfony/polyfill-php80/Resources/stubs/ValueError.php +16 -0
- package/vendor/symfony/polyfill-php80/bootstrap.php +42 -0
- package/vendor/symfony/polyfill-php80/composer.json +40 -0
- package/vendor/vlucas/phpdotenv/.editorconfig +15 -0
- package/vendor/vlucas/phpdotenv/.gitattributes +17 -0
- package/vendor/vlucas/phpdotenv/.github/CODE_OF_CONDUCT.md +132 -0
- package/vendor/vlucas/phpdotenv/.github/CONTRIBUTING.md +30 -0
- package/vendor/vlucas/phpdotenv/.github/FUNDING.yml +2 -0
- package/vendor/vlucas/phpdotenv/.github/SECURITY.md +14 -0
- package/vendor/vlucas/phpdotenv/.github/workflows/static.yml +74 -0
- package/vendor/vlucas/phpdotenv/.github/workflows/tests.yml +70 -0
- package/vendor/vlucas/phpdotenv/LICENSE +30 -0
- package/vendor/vlucas/phpdotenv/Makefile +26 -0
- package/vendor/vlucas/phpdotenv/README.md +363 -0
- package/vendor/vlucas/phpdotenv/UPGRADING.md +196 -0
- package/vendor/vlucas/phpdotenv/composer.json +60 -0
- package/vendor/vlucas/phpdotenv/phpstan-baseline.neon +21 -0
- package/vendor/vlucas/phpdotenv/phpstan.neon.dist +7 -0
- package/vendor/vlucas/phpdotenv/phpunit.xml.dist +13 -0
- package/vendor/vlucas/phpdotenv/psalm-baseline.xml +28 -0
- package/vendor/vlucas/phpdotenv/psalm.xml +13 -0
- package/vendor/vlucas/phpdotenv/src/Dotenv.php +267 -0
- package/vendor/vlucas/phpdotenv/src/Exception/ExceptionInterface.php +12 -0
- package/vendor/vlucas/phpdotenv/src/Exception/InvalidEncodingException.php +12 -0
- package/vendor/vlucas/phpdotenv/src/Exception/InvalidFileException.php +12 -0
- package/vendor/vlucas/phpdotenv/src/Exception/InvalidPathException.php +12 -0
- package/vendor/vlucas/phpdotenv/src/Exception/ValidationException.php +12 -0
- package/vendor/vlucas/phpdotenv/src/Loader/Loader.php +47 -0
- package/vendor/vlucas/phpdotenv/src/Loader/LoaderInterface.php +20 -0
- package/vendor/vlucas/phpdotenv/src/Loader/Resolver.php +65 -0
- package/vendor/vlucas/phpdotenv/src/Parser/Entry.php +59 -0
- package/vendor/vlucas/phpdotenv/src/Parser/EntryParser.php +300 -0
- package/vendor/vlucas/phpdotenv/src/Parser/Lexer.php +58 -0
- package/vendor/vlucas/phpdotenv/src/Parser/Lines.php +127 -0
- package/vendor/vlucas/phpdotenv/src/Parser/Parser.php +53 -0
- package/vendor/vlucas/phpdotenv/src/Parser/ParserInterface.php +19 -0
- package/vendor/vlucas/phpdotenv/src/Parser/Value.php +88 -0
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/AdapterInterface.php +15 -0
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/ApacheAdapter.php +89 -0
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/ArrayAdapter.php +80 -0
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/EnvConstAdapter.php +89 -0
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/GuardedWriter.php +85 -0
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/ImmutableWriter.php +110 -0
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/MultiReader.php +48 -0
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/MultiWriter.php +64 -0
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/PutenvAdapter.php +91 -0
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/ReaderInterface.php +17 -0
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/ReplacingWriter.php +104 -0
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/ServerConstAdapter.php +89 -0
- package/vendor/vlucas/phpdotenv/src/Repository/Adapter/WriterInterface.php +27 -0
- package/vendor/vlucas/phpdotenv/src/Repository/AdapterRepository.php +107 -0
- package/vendor/vlucas/phpdotenv/src/Repository/RepositoryBuilder.php +272 -0
- package/vendor/vlucas/phpdotenv/src/Repository/RepositoryInterface.php +51 -0
- package/vendor/vlucas/phpdotenv/src/Store/File/Paths.php +44 -0
- package/vendor/vlucas/phpdotenv/src/Store/File/Reader.php +81 -0
- package/vendor/vlucas/phpdotenv/src/Store/FileStore.php +72 -0
- package/vendor/vlucas/phpdotenv/src/Store/StoreBuilder.php +141 -0
- package/vendor/vlucas/phpdotenv/src/Store/StoreInterface.php +17 -0
- package/vendor/vlucas/phpdotenv/src/Store/StringStore.php +37 -0
- package/vendor/vlucas/phpdotenv/src/Util/Regex.php +112 -0
- package/vendor/vlucas/phpdotenv/src/Util/Str.php +98 -0
- package/vendor/vlucas/phpdotenv/src/Validator.php +209 -0
- package/vendor/vlucas/phpdotenv/tests/Dotenv/DotenvTest.php +387 -0
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Loader/LoaderTest.php +86 -0
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Parser/EntryParserTest.php +234 -0
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Parser/LexerTest.php +40 -0
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Parser/LinesTest.php +53 -0
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Parser/ParserTest.php +98 -0
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/Adapter/ArrayAdapterTest.php +57 -0
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/Adapter/EnvConstAdapterTest.php +75 -0
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/Adapter/PutenvAdapterTest.php +52 -0
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/Adapter/ServerConstAdapterTest.php +75 -0
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/RepositoryTest.php +305 -0
- package/vendor/vlucas/phpdotenv/tests/Dotenv/Store/StoreTest.php +141 -0
- package/vendor/vlucas/phpdotenv/tests/Dotenv/ValidatorTest.php +479 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/.env +5 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/assertions.env +18 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/booleans.env +33 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/commented.env +15 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/empty.env +1 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/example.env +1 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/exported.env +7 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/immutable.env +1 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/integers.env +17 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/large.env +2 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/multibyte.env +3 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/multiline.env +14 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/multiple.env +4 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/mutable.env +1 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/nested.env +15 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/quoted.env +11 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/specialchars.env +8 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/unicodevarnames.env +2 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/utf8-with-bom-encoding.env +3 -0
- package/vendor/vlucas/phpdotenv/tests/fixtures/env/windows.env +1 -0
- package/vendor/vlucas/phpdotenv/vendor-bin/phpstan/composer.json +16 -0
- package/vendor/vlucas/phpdotenv/vendor-bin/psalm/composer.json +9 -0
|
@@ -0,0 +1,543 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
namespace Firebase\JWT;
|
|
4
|
+
|
|
5
|
+
use ArrayObject;
|
|
6
|
+
use DomainException;
|
|
7
|
+
use InvalidArgumentException;
|
|
8
|
+
use PHPUnit\Framework\TestCase;
|
|
9
|
+
use stdClass;
|
|
10
|
+
use TypeError;
|
|
11
|
+
use UnexpectedValueException;
|
|
12
|
+
|
|
13
|
+
class JWTTest extends TestCase
|
|
14
|
+
{
|
|
15
|
+
public function testUrlSafeCharacters()
|
|
16
|
+
{
|
|
17
|
+
$encoded = JWT::encode(['message' => 'f?'], 'a', 'HS256');
|
|
18
|
+
$expected = new stdClass();
|
|
19
|
+
$expected->message = 'f?';
|
|
20
|
+
$this->assertEquals($expected, JWT::decode($encoded, new Key('a', 'HS256')));
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
public function testMalformedUtf8StringsFail()
|
|
24
|
+
{
|
|
25
|
+
$this->expectException(DomainException::class);
|
|
26
|
+
JWT::encode(['message' => pack('c', 128)], 'a', 'HS256');
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
public function testMalformedJsonThrowsException()
|
|
30
|
+
{
|
|
31
|
+
$this->expectException(DomainException::class);
|
|
32
|
+
JWT::jsonDecode('this is not valid JSON string');
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
public function testExpiredToken()
|
|
36
|
+
{
|
|
37
|
+
$this->expectException(ExpiredException::class);
|
|
38
|
+
$payload = [
|
|
39
|
+
'message' => 'abc',
|
|
40
|
+
'exp' => time() - 20, // time in the past
|
|
41
|
+
];
|
|
42
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
43
|
+
JWT::decode($encoded, new Key('my_key', 'HS256'));
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
public function testBeforeValidTokenWithNbf()
|
|
47
|
+
{
|
|
48
|
+
$this->expectException(BeforeValidException::class);
|
|
49
|
+
$payload = [
|
|
50
|
+
'message' => 'abc',
|
|
51
|
+
'nbf' => time() + 20, // time in the future
|
|
52
|
+
];
|
|
53
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
54
|
+
JWT::decode($encoded, new Key('my_key', 'HS256'));
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
public function testBeforeValidTokenWithIat()
|
|
58
|
+
{
|
|
59
|
+
$this->expectException(BeforeValidException::class);
|
|
60
|
+
$payload = [
|
|
61
|
+
'message' => 'abc',
|
|
62
|
+
'iat' => time() + 20, // time in the future
|
|
63
|
+
];
|
|
64
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
65
|
+
JWT::decode($encoded, new Key('my_key', 'HS256'));
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
public function testValidToken()
|
|
69
|
+
{
|
|
70
|
+
$payload = [
|
|
71
|
+
'message' => 'abc',
|
|
72
|
+
'exp' => time() + JWT::$leeway + 20, // time in the future
|
|
73
|
+
];
|
|
74
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
75
|
+
$decoded = JWT::decode($encoded, new Key('my_key', 'HS256'));
|
|
76
|
+
$this->assertSame($decoded->message, 'abc');
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
/**
|
|
80
|
+
* @runInSeparateProcess
|
|
81
|
+
*/
|
|
82
|
+
public function testValidTokenWithLeeway()
|
|
83
|
+
{
|
|
84
|
+
JWT::$leeway = 60;
|
|
85
|
+
$payload = [
|
|
86
|
+
'message' => 'abc',
|
|
87
|
+
'exp' => time() - 20, // time in the past
|
|
88
|
+
];
|
|
89
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
90
|
+
$decoded = JWT::decode($encoded, new Key('my_key', 'HS256'));
|
|
91
|
+
$this->assertSame($decoded->message, 'abc');
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
/**
|
|
95
|
+
* @runInSeparateProcess
|
|
96
|
+
*/
|
|
97
|
+
public function testExpiredTokenWithLeeway()
|
|
98
|
+
{
|
|
99
|
+
JWT::$leeway = 60;
|
|
100
|
+
$payload = [
|
|
101
|
+
'message' => 'abc',
|
|
102
|
+
'exp' => time() - 70, // time far in the past
|
|
103
|
+
];
|
|
104
|
+
$this->expectException(ExpiredException::class);
|
|
105
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
106
|
+
$decoded = JWT::decode($encoded, new Key('my_key', 'HS256'));
|
|
107
|
+
$this->assertSame($decoded->message, 'abc');
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
public function testExpiredExceptionPayload()
|
|
111
|
+
{
|
|
112
|
+
$this->expectException(ExpiredException::class);
|
|
113
|
+
$payload = [
|
|
114
|
+
'message' => 'abc',
|
|
115
|
+
'exp' => time() - 100, // time in the past
|
|
116
|
+
];
|
|
117
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
118
|
+
try {
|
|
119
|
+
JWT::decode($encoded, new Key('my_key', 'HS256'));
|
|
120
|
+
} catch (ExpiredException $e) {
|
|
121
|
+
$exceptionPayload = (array) $e->getPayload();
|
|
122
|
+
$this->assertEquals($exceptionPayload, $payload);
|
|
123
|
+
throw $e;
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
public function testBeforeValidExceptionPayload()
|
|
128
|
+
{
|
|
129
|
+
$this->expectException(BeforeValidException::class);
|
|
130
|
+
$payload = [
|
|
131
|
+
'message' => 'abc',
|
|
132
|
+
'iat' => time() + 100, // time in the future
|
|
133
|
+
];
|
|
134
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
135
|
+
try {
|
|
136
|
+
JWT::decode($encoded, new Key('my_key', 'HS256'));
|
|
137
|
+
} catch (BeforeValidException $e) {
|
|
138
|
+
$exceptionPayload = (array) $e->getPayload();
|
|
139
|
+
$this->assertEquals($exceptionPayload, $payload);
|
|
140
|
+
throw $e;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
public function testValidTokenWithNbf()
|
|
145
|
+
{
|
|
146
|
+
$payload = [
|
|
147
|
+
'message' => 'abc',
|
|
148
|
+
'iat' => time(),
|
|
149
|
+
'exp' => time() + 20, // time in the future
|
|
150
|
+
'nbf' => time() - 20
|
|
151
|
+
];
|
|
152
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
153
|
+
$decoded = JWT::decode($encoded, new Key('my_key', 'HS256'));
|
|
154
|
+
$this->assertSame($decoded->message, 'abc');
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
/**
|
|
158
|
+
* @runInSeparateProcess
|
|
159
|
+
*/
|
|
160
|
+
public function testValidTokenWithNbfLeeway()
|
|
161
|
+
{
|
|
162
|
+
JWT::$leeway = 60;
|
|
163
|
+
$payload = [
|
|
164
|
+
'message' => 'abc',
|
|
165
|
+
'nbf' => time() + 20, // not before in near (leeway) future
|
|
166
|
+
];
|
|
167
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
168
|
+
$decoded = JWT::decode($encoded, new Key('my_key', 'HS256'));
|
|
169
|
+
$this->assertSame($decoded->message, 'abc');
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
/**
|
|
173
|
+
* @runInSeparateProcess
|
|
174
|
+
*/
|
|
175
|
+
public function testInvalidTokenWithNbfLeeway()
|
|
176
|
+
{
|
|
177
|
+
JWT::$leeway = 60;
|
|
178
|
+
$payload = [
|
|
179
|
+
'message' => 'abc',
|
|
180
|
+
'nbf' => time() + 65, // not before too far in future
|
|
181
|
+
];
|
|
182
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
183
|
+
$this->expectException(BeforeValidException::class);
|
|
184
|
+
$this->expectExceptionMessage('Cannot handle token with nbf prior to');
|
|
185
|
+
JWT::decode($encoded, new Key('my_key', 'HS256'));
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
public function testValidTokenWithNbfIgnoresIat()
|
|
189
|
+
{
|
|
190
|
+
$payload = [
|
|
191
|
+
'message' => 'abc',
|
|
192
|
+
'nbf' => time() - 20, // time in the future
|
|
193
|
+
'iat' => time() + 20, // time in the past
|
|
194
|
+
];
|
|
195
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
196
|
+
$decoded = JWT::decode($encoded, new Key('my_key', 'HS256'));
|
|
197
|
+
$this->assertEquals('abc', $decoded->message);
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
public function testValidTokenWithNbfMicrotime()
|
|
201
|
+
{
|
|
202
|
+
$payload = [
|
|
203
|
+
'message' => 'abc',
|
|
204
|
+
'nbf' => microtime(true), // use microtime
|
|
205
|
+
];
|
|
206
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
207
|
+
$decoded = JWT::decode($encoded, new Key('my_key', 'HS256'));
|
|
208
|
+
$this->assertEquals('abc', $decoded->message);
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
public function testInvalidTokenWithNbfMicrotime()
|
|
212
|
+
{
|
|
213
|
+
$this->expectException(BeforeValidException::class);
|
|
214
|
+
$this->expectExceptionMessage('Cannot handle token with nbf prior to');
|
|
215
|
+
$payload = [
|
|
216
|
+
'message' => 'abc',
|
|
217
|
+
'nbf' => microtime(true) + 20, // use microtime in the future
|
|
218
|
+
];
|
|
219
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
220
|
+
JWT::decode($encoded, new Key('my_key', 'HS256'));
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
/**
|
|
224
|
+
* @runInSeparateProcess
|
|
225
|
+
*/
|
|
226
|
+
public function testValidTokenWithIatLeeway()
|
|
227
|
+
{
|
|
228
|
+
JWT::$leeway = 60;
|
|
229
|
+
$payload = [
|
|
230
|
+
'message' => 'abc',
|
|
231
|
+
'iat' => time() + 20, // issued in near (leeway) future
|
|
232
|
+
];
|
|
233
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
234
|
+
$decoded = JWT::decode($encoded, new Key('my_key', 'HS256'));
|
|
235
|
+
$this->assertSame($decoded->message, 'abc');
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
/**
|
|
239
|
+
* @runInSeparateProcess
|
|
240
|
+
*/
|
|
241
|
+
public function testInvalidTokenWithIatLeeway()
|
|
242
|
+
{
|
|
243
|
+
JWT::$leeway = 60;
|
|
244
|
+
$payload = [
|
|
245
|
+
'message' => 'abc',
|
|
246
|
+
'iat' => time() + 65, // issued too far in future
|
|
247
|
+
];
|
|
248
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
249
|
+
$this->expectException(BeforeValidException::class);
|
|
250
|
+
$this->expectExceptionMessage('Cannot handle token with iat prior to');
|
|
251
|
+
JWT::decode($encoded, new Key('my_key', 'HS256'));
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
public function testValidTokenWithIatMicrotime()
|
|
255
|
+
{
|
|
256
|
+
$payload = [
|
|
257
|
+
'message' => 'abc',
|
|
258
|
+
'iat' => microtime(true), // use microtime
|
|
259
|
+
];
|
|
260
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
261
|
+
$decoded = JWT::decode($encoded, new Key('my_key', 'HS256'));
|
|
262
|
+
$this->assertEquals('abc', $decoded->message);
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
public function testInvalidTokenWithIatMicrotime()
|
|
266
|
+
{
|
|
267
|
+
$this->expectException(BeforeValidException::class);
|
|
268
|
+
$this->expectExceptionMessage('Cannot handle token with iat prior to');
|
|
269
|
+
$payload = [
|
|
270
|
+
'message' => 'abc',
|
|
271
|
+
'iat' => microtime(true) + 20, // use microtime in the future
|
|
272
|
+
];
|
|
273
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
274
|
+
JWT::decode($encoded, new Key('my_key', 'HS256'));
|
|
275
|
+
}
|
|
276
|
+
|
|
277
|
+
public function testInvalidToken()
|
|
278
|
+
{
|
|
279
|
+
$payload = [
|
|
280
|
+
'message' => 'abc',
|
|
281
|
+
'exp' => time() + 20, // time in the future
|
|
282
|
+
];
|
|
283
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
284
|
+
$this->expectException(SignatureInvalidException::class);
|
|
285
|
+
JWT::decode($encoded, new Key('my_key2', 'HS256'));
|
|
286
|
+
}
|
|
287
|
+
|
|
288
|
+
public function testNullKeyFails()
|
|
289
|
+
{
|
|
290
|
+
$payload = [
|
|
291
|
+
'message' => 'abc',
|
|
292
|
+
'exp' => time() + JWT::$leeway + 20, // time in the future
|
|
293
|
+
];
|
|
294
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
295
|
+
$this->expectException(TypeError::class);
|
|
296
|
+
JWT::decode($encoded, new Key(null, 'HS256'));
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
public function testEmptyKeyFails()
|
|
300
|
+
{
|
|
301
|
+
$payload = [
|
|
302
|
+
'message' => 'abc',
|
|
303
|
+
'exp' => time() + JWT::$leeway + 20, // time in the future
|
|
304
|
+
];
|
|
305
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
306
|
+
$this->expectException(InvalidArgumentException::class);
|
|
307
|
+
JWT::decode($encoded, new Key('', 'HS256'));
|
|
308
|
+
}
|
|
309
|
+
|
|
310
|
+
public function testKIDChooser()
|
|
311
|
+
{
|
|
312
|
+
$keys = [
|
|
313
|
+
'0' => new Key('my_key0', 'HS256'),
|
|
314
|
+
'1' => new Key('my_key1', 'HS256'),
|
|
315
|
+
'2' => new Key('my_key2', 'HS256')
|
|
316
|
+
];
|
|
317
|
+
$msg = JWT::encode(['message' => 'abc'], $keys['0']->getKeyMaterial(), 'HS256', '0');
|
|
318
|
+
$decoded = JWT::decode($msg, $keys);
|
|
319
|
+
$expected = new stdClass();
|
|
320
|
+
$expected->message = 'abc';
|
|
321
|
+
$this->assertEquals($decoded, $expected);
|
|
322
|
+
}
|
|
323
|
+
|
|
324
|
+
public function testArrayAccessKIDChooser()
|
|
325
|
+
{
|
|
326
|
+
$keys = new ArrayObject([
|
|
327
|
+
'0' => new Key('my_key0', 'HS256'),
|
|
328
|
+
'1' => new Key('my_key1', 'HS256'),
|
|
329
|
+
'2' => new Key('my_key2', 'HS256'),
|
|
330
|
+
]);
|
|
331
|
+
$msg = JWT::encode(['message' => 'abc'], $keys['0']->getKeyMaterial(), 'HS256', '0');
|
|
332
|
+
$decoded = JWT::decode($msg, $keys);
|
|
333
|
+
$expected = new stdClass();
|
|
334
|
+
$expected->message = 'abc';
|
|
335
|
+
$this->assertEquals($decoded, $expected);
|
|
336
|
+
}
|
|
337
|
+
|
|
338
|
+
public function testNoneAlgorithm()
|
|
339
|
+
{
|
|
340
|
+
$msg = JWT::encode(['message' => 'abc'], 'my_key', 'HS256');
|
|
341
|
+
$this->expectException(UnexpectedValueException::class);
|
|
342
|
+
JWT::decode($msg, new Key('my_key', 'none'));
|
|
343
|
+
}
|
|
344
|
+
|
|
345
|
+
public function testIncorrectAlgorithm()
|
|
346
|
+
{
|
|
347
|
+
$msg = JWT::encode(['message' => 'abc'], 'my_key', 'HS256');
|
|
348
|
+
$this->expectException(UnexpectedValueException::class);
|
|
349
|
+
JWT::decode($msg, new Key('my_key', 'RS256'));
|
|
350
|
+
}
|
|
351
|
+
|
|
352
|
+
public function testEmptyAlgorithm()
|
|
353
|
+
{
|
|
354
|
+
$msg = JWT::encode(['message' => 'abc'], 'my_key', 'HS256');
|
|
355
|
+
$this->expectException(InvalidArgumentException::class);
|
|
356
|
+
JWT::decode($msg, new Key('my_key', ''));
|
|
357
|
+
}
|
|
358
|
+
|
|
359
|
+
public function testAdditionalHeaders()
|
|
360
|
+
{
|
|
361
|
+
$msg = JWT::encode(['message' => 'abc'], 'my_key', 'HS256', null, ['cty' => 'test-eit;v=1']);
|
|
362
|
+
$expected = new stdClass();
|
|
363
|
+
$expected->message = 'abc';
|
|
364
|
+
$this->assertEquals(JWT::decode($msg, new Key('my_key', 'HS256')), $expected);
|
|
365
|
+
}
|
|
366
|
+
|
|
367
|
+
public function testInvalidSegmentCount()
|
|
368
|
+
{
|
|
369
|
+
$this->expectException(UnexpectedValueException::class);
|
|
370
|
+
JWT::decode('brokenheader.brokenbody', new Key('my_key', 'HS256'));
|
|
371
|
+
}
|
|
372
|
+
|
|
373
|
+
public function testInvalidSignatureEncoding()
|
|
374
|
+
{
|
|
375
|
+
$msg = 'eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpZCI6MSwibmFtZSI6ImZvbyJ9.Q4Kee9E8o0Xfo4ADXvYA8t7dN_X_bU9K5w6tXuiSjlUxx';
|
|
376
|
+
$this->expectException(UnexpectedValueException::class);
|
|
377
|
+
JWT::decode($msg, new Key('secret', 'HS256'));
|
|
378
|
+
}
|
|
379
|
+
|
|
380
|
+
public function testHSEncodeDecode()
|
|
381
|
+
{
|
|
382
|
+
$msg = JWT::encode(['message' => 'abc'], 'my_key', 'HS256');
|
|
383
|
+
$expected = new stdClass();
|
|
384
|
+
$expected->message = 'abc';
|
|
385
|
+
$this->assertEquals(JWT::decode($msg, new Key('my_key', 'HS256')), $expected);
|
|
386
|
+
}
|
|
387
|
+
|
|
388
|
+
public function testRSEncodeDecode()
|
|
389
|
+
{
|
|
390
|
+
$privKey = openssl_pkey_new(['digest_alg' => 'sha256',
|
|
391
|
+
'private_key_bits' => 1024,
|
|
392
|
+
'private_key_type' => OPENSSL_KEYTYPE_RSA]);
|
|
393
|
+
$msg = JWT::encode(['message' => 'abc'], $privKey, 'RS256');
|
|
394
|
+
$pubKey = openssl_pkey_get_details($privKey);
|
|
395
|
+
$pubKey = $pubKey['key'];
|
|
396
|
+
$decoded = JWT::decode($msg, new Key($pubKey, 'RS256'));
|
|
397
|
+
$expected = new stdClass();
|
|
398
|
+
$expected->message = 'abc';
|
|
399
|
+
$this->assertEquals($decoded, $expected);
|
|
400
|
+
}
|
|
401
|
+
|
|
402
|
+
public function testEdDsaEncodeDecode()
|
|
403
|
+
{
|
|
404
|
+
$keyPair = sodium_crypto_sign_keypair();
|
|
405
|
+
$privKey = base64_encode(sodium_crypto_sign_secretkey($keyPair));
|
|
406
|
+
|
|
407
|
+
$payload = ['foo' => 'bar'];
|
|
408
|
+
$msg = JWT::encode($payload, $privKey, 'EdDSA');
|
|
409
|
+
|
|
410
|
+
$pubKey = base64_encode(sodium_crypto_sign_publickey($keyPair));
|
|
411
|
+
$decoded = JWT::decode($msg, new Key($pubKey, 'EdDSA'));
|
|
412
|
+
$this->assertSame('bar', $decoded->foo);
|
|
413
|
+
}
|
|
414
|
+
|
|
415
|
+
public function testInvalidEdDsaEncodeDecode()
|
|
416
|
+
{
|
|
417
|
+
$keyPair = sodium_crypto_sign_keypair();
|
|
418
|
+
$privKey = base64_encode(sodium_crypto_sign_secretkey($keyPair));
|
|
419
|
+
|
|
420
|
+
$payload = ['foo' => 'bar'];
|
|
421
|
+
$msg = JWT::encode($payload, $privKey, 'EdDSA');
|
|
422
|
+
|
|
423
|
+
// Generate a different key.
|
|
424
|
+
$keyPair = sodium_crypto_sign_keypair();
|
|
425
|
+
$pubKey = base64_encode(sodium_crypto_sign_publickey($keyPair));
|
|
426
|
+
$this->expectException(SignatureInvalidException::class);
|
|
427
|
+
JWT::decode($msg, new Key($pubKey, 'EdDSA'));
|
|
428
|
+
}
|
|
429
|
+
|
|
430
|
+
public function testRSEncodeDecodeWithPassphrase()
|
|
431
|
+
{
|
|
432
|
+
$privateKey = openssl_pkey_get_private(
|
|
433
|
+
file_get_contents(__DIR__ . '/data/rsa-with-passphrase.pem'),
|
|
434
|
+
'passphrase'
|
|
435
|
+
);
|
|
436
|
+
|
|
437
|
+
$jwt = JWT::encode(['message' => 'abc'], $privateKey, 'RS256');
|
|
438
|
+
$keyDetails = openssl_pkey_get_details($privateKey);
|
|
439
|
+
$pubKey = $keyDetails['key'];
|
|
440
|
+
$decoded = JWT::decode($jwt, new Key($pubKey, 'RS256'));
|
|
441
|
+
$expected = new stdClass();
|
|
442
|
+
$expected->message = 'abc';
|
|
443
|
+
$this->assertEquals($decoded, $expected);
|
|
444
|
+
}
|
|
445
|
+
|
|
446
|
+
public function testDecodesEmptyArrayAsObject()
|
|
447
|
+
{
|
|
448
|
+
$key = 'yma6Hq4XQegCVND8ef23OYgxSrC3IKqk';
|
|
449
|
+
$payload = [];
|
|
450
|
+
$jwt = JWT::encode($payload, $key, 'HS256');
|
|
451
|
+
$decoded = JWT::decode($jwt, new Key($key, 'HS256'));
|
|
452
|
+
$this->assertEquals((object) $payload, $decoded);
|
|
453
|
+
}
|
|
454
|
+
|
|
455
|
+
public function testDecodesArraysInJWTAsArray()
|
|
456
|
+
{
|
|
457
|
+
$key = 'yma6Hq4XQegCVND8ef23OYgxSrC3IKqk';
|
|
458
|
+
$payload = ['foo' => [1, 2, 3]];
|
|
459
|
+
$jwt = JWT::encode($payload, $key, 'HS256');
|
|
460
|
+
$decoded = JWT::decode($jwt, new Key($key, 'HS256'));
|
|
461
|
+
$this->assertSame($payload['foo'], $decoded->foo);
|
|
462
|
+
}
|
|
463
|
+
|
|
464
|
+
/**
|
|
465
|
+
* @runInSeparateProcess
|
|
466
|
+
* @dataProvider provideEncodeDecode
|
|
467
|
+
*/
|
|
468
|
+
public function testEncodeDecode($privateKeyFile, $publicKeyFile, $alg)
|
|
469
|
+
{
|
|
470
|
+
$privateKey = file_get_contents($privateKeyFile);
|
|
471
|
+
$payload = ['foo' => 'bar'];
|
|
472
|
+
$encoded = JWT::encode($payload, $privateKey, $alg);
|
|
473
|
+
|
|
474
|
+
// Verify decoding succeeds
|
|
475
|
+
$publicKey = file_get_contents($publicKeyFile);
|
|
476
|
+
$decoded = JWT::decode($encoded, new Key($publicKey, $alg));
|
|
477
|
+
|
|
478
|
+
$this->assertSame('bar', $decoded->foo);
|
|
479
|
+
}
|
|
480
|
+
|
|
481
|
+
public function provideEncodeDecode()
|
|
482
|
+
{
|
|
483
|
+
return [
|
|
484
|
+
[__DIR__ . '/data/ecdsa-private.pem', __DIR__ . '/data/ecdsa-public.pem', 'ES256'],
|
|
485
|
+
[__DIR__ . '/data/ecdsa384-private.pem', __DIR__ . '/data/ecdsa384-public.pem', 'ES384'],
|
|
486
|
+
[__DIR__ . '/data/rsa1-private.pem', __DIR__ . '/data/rsa1-public.pub', 'RS512'],
|
|
487
|
+
[__DIR__ . '/data/ed25519-1.sec', __DIR__ . '/data/ed25519-1.pub', 'EdDSA'],
|
|
488
|
+
[__DIR__ . '/data/secp256k1-private.pem', __DIR__ . '/data/secp256k1-public.pem', 'ES256K'],
|
|
489
|
+
];
|
|
490
|
+
}
|
|
491
|
+
|
|
492
|
+
public function testEncodeDecodeWithResource()
|
|
493
|
+
{
|
|
494
|
+
$pem = file_get_contents(__DIR__ . '/data/rsa1-public.pub');
|
|
495
|
+
$resource = openssl_pkey_get_public($pem);
|
|
496
|
+
$privateKey = file_get_contents(__DIR__ . '/data/rsa1-private.pem');
|
|
497
|
+
|
|
498
|
+
$payload = ['foo' => 'bar'];
|
|
499
|
+
$encoded = JWT::encode($payload, $privateKey, 'RS512');
|
|
500
|
+
|
|
501
|
+
// Verify decoding succeeds
|
|
502
|
+
$decoded = JWT::decode($encoded, new Key($resource, 'RS512'));
|
|
503
|
+
|
|
504
|
+
$this->assertSame('bar', $decoded->foo);
|
|
505
|
+
}
|
|
506
|
+
|
|
507
|
+
public function testGetHeaders()
|
|
508
|
+
{
|
|
509
|
+
$payload = [
|
|
510
|
+
'message' => 'abc',
|
|
511
|
+
'exp' => time() + JWT::$leeway + 20, // time in the future
|
|
512
|
+
];
|
|
513
|
+
$headers = new stdClass();
|
|
514
|
+
|
|
515
|
+
$encoded = JWT::encode($payload, 'my_key', 'HS256');
|
|
516
|
+
JWT::decode($encoded, new Key('my_key', 'HS256'), $headers);
|
|
517
|
+
|
|
518
|
+
$this->assertEquals($headers->typ, 'JWT');
|
|
519
|
+
$this->assertEquals($headers->alg, 'HS256');
|
|
520
|
+
}
|
|
521
|
+
|
|
522
|
+
public function testAdditionalHeaderOverrides()
|
|
523
|
+
{
|
|
524
|
+
$msg = JWT::encode(
|
|
525
|
+
['message' => 'abc'],
|
|
526
|
+
'my_key',
|
|
527
|
+
'HS256',
|
|
528
|
+
'my_key_id',
|
|
529
|
+
[
|
|
530
|
+
'cty' => 'test-eit;v=1',
|
|
531
|
+
'typ' => 'JOSE', // override type header
|
|
532
|
+
'kid' => 'not_my_key_id', // should not override $key param
|
|
533
|
+
'alg' => 'BAD', // should not override $alg param
|
|
534
|
+
]
|
|
535
|
+
);
|
|
536
|
+
$headers = new stdClass();
|
|
537
|
+
JWT::decode($msg, new Key('my_key', 'HS256'), $headers);
|
|
538
|
+
$this->assertEquals('test-eit;v=1', $headers->cty, 'additional field works');
|
|
539
|
+
$this->assertEquals('JOSE', $headers->typ, 'typ override works');
|
|
540
|
+
$this->assertEquals('my_key_id', $headers->kid, 'key param not overridden');
|
|
541
|
+
$this->assertEquals('HS256', $headers->alg, 'alg param not overridden');
|
|
542
|
+
}
|
|
543
|
+
}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
{
|
|
2
|
+
"keys": [
|
|
3
|
+
{
|
|
4
|
+
"kty": "EC",
|
|
5
|
+
"use": "sig",
|
|
6
|
+
"crv": "P-256",
|
|
7
|
+
"kid": "jwk1",
|
|
8
|
+
"x": "ALXnvdCvbBx35J2bozBkIFHPT747KiYioLK4JquMhZU",
|
|
9
|
+
"y": "fAt_rGPqS95Ytwdluh4TNWTmj9xkcAbKGBRpP5kuGBk",
|
|
10
|
+
"alg": "ES256"
|
|
11
|
+
},
|
|
12
|
+
{
|
|
13
|
+
"kty": "EC",
|
|
14
|
+
"use": "sig",
|
|
15
|
+
"crv": "P-256",
|
|
16
|
+
"kid": "jwk2",
|
|
17
|
+
"x": "mQa0q5FvxPRujxzFazQT1Mo2YJJzuKiXU3svOJ41jhw",
|
|
18
|
+
"y": "jAz7UwIl2oOFk06kj42ZFMOXmGMFUGjKASvyYtibCH0",
|
|
19
|
+
"alg": "ES256"
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
"kty": "EC",
|
|
23
|
+
"use": "sig",
|
|
24
|
+
"crv": "secp256k1",
|
|
25
|
+
"kid": "jwk3",
|
|
26
|
+
"x": "EFpwNuP322bU3WP1DtJgx67L0CUV1MxNixqPVMH2L9Q",
|
|
27
|
+
"y": "_fSTbijIJjpsqL16cIEvxxf3MaYMY8MbqEq066yV9ls",
|
|
28
|
+
"alg": "ES256K"
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
"kty": "EC",
|
|
32
|
+
"use": "sig",
|
|
33
|
+
"crv": "P-384",
|
|
34
|
+
"kid": "jwk4",
|
|
35
|
+
"x": "FhXXcyKmWkTkdVbWYYU3dtJqpJ0JmLGftEdNzUEFEKSU5MlnLr_FjcneszvXAqEB",
|
|
36
|
+
"y": "M4veJF_dO_zhFk44bh_ELXbp0_nn9QaViVtQpuTvpu29eefx6PfUMqX0K--IS4NQ",
|
|
37
|
+
"alg": "ES384"
|
|
38
|
+
}
|
|
39
|
+
]
|
|
40
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
-----BEGIN EC PARAMETERS-----
|
|
2
|
+
MIH3AgEBMCwGByqGSM49AQECIQD/////AAAAAQAAAAAAAAAAAAAAAP//////////
|
|
3
|
+
/////zBbBCD/////AAAAAQAAAAAAAAAAAAAAAP///////////////AQgWsY12Ko6
|
|
4
|
+
k+ez671VdpiGvGUdBrDMU7D2O848PifSYEsDFQDEnTYIhucEk2pmeOETnSa3gZ9+
|
|
5
|
+
kARBBGsX0fLhLEJH+Lzm5WOkQPJ3A32BLeszoPShOUXYmMKWT+NC4v4af5uO5+tK
|
|
6
|
+
fA+eFivOM1drMV7Oy7ZAaDe/UfUCIQD/////AAAAAP//////////vOb6racXnoTz
|
|
7
|
+
ucrC/GMlUQIBAQ==
|
|
8
|
+
-----END EC PARAMETERS-----
|
|
9
|
+
-----BEGIN EC PRIVATE KEY-----
|
|
10
|
+
MIIBaAIBAQQgyP9e7yS1tjpXa0l6o+80dbSxuMcqx3lUg0n2OT9AmiuggfowgfcC
|
|
11
|
+
AQEwLAYHKoZIzj0BAQIhAP////8AAAABAAAAAAAAAAAAAAAA////////////////
|
|
12
|
+
MFsEIP////8AAAABAAAAAAAAAAAAAAAA///////////////8BCBaxjXYqjqT57Pr
|
|
13
|
+
vVV2mIa8ZR0GsMxTsPY7zjw+J9JgSwMVAMSdNgiG5wSTamZ44ROdJreBn36QBEEE
|
|
14
|
+
axfR8uEsQkf4vOblY6RA8ncDfYEt6zOg9KE5RdiYwpZP40Li/hp/m47n60p8D54W
|
|
15
|
+
K84zV2sxXs7LtkBoN79R9QIhAP////8AAAAA//////////+85vqtpxeehPO5ysL8
|
|
16
|
+
YyVRAgEBoUQDQgAE2klp6aX6y5kAir3EWQt0QAeapTW+db/9fD65KAoDzVajtThx
|
|
17
|
+
PVLEf1CufcfTxMQAQPM3wkZhu0NjlWFetcMdcQ==
|
|
18
|
+
-----END EC PRIVATE KEY-----
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
-----BEGIN PUBLIC KEY-----
|
|
2
|
+
MIIBSzCCAQMGByqGSM49AgEwgfcCAQEwLAYHKoZIzj0BAQIhAP////8AAAABAAAA
|
|
3
|
+
AAAAAAAAAAAA////////////////MFsEIP////8AAAABAAAAAAAAAAAAAAAA////
|
|
4
|
+
///////////8BCBaxjXYqjqT57PrvVV2mIa8ZR0GsMxTsPY7zjw+J9JgSwMVAMSd
|
|
5
|
+
NgiG5wSTamZ44ROdJreBn36QBEEEaxfR8uEsQkf4vOblY6RA8ncDfYEt6zOg9KE5
|
|
6
|
+
RdiYwpZP40Li/hp/m47n60p8D54WK84zV2sxXs7LtkBoN79R9QIhAP////8AAAAA
|
|
7
|
+
//////////+85vqtpxeehPO5ysL8YyVRAgEBA0IABNpJaeml+suZAIq9xFkLdEAH
|
|
8
|
+
mqU1vnW//Xw+uSgKA81Wo7U4cT1SxH9Qrn3H08TEAEDzN8JGYbtDY5VhXrXDHXE=
|
|
9
|
+
-----END PUBLIC KEY-----
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
-----BEGIN EC PRIVATE KEY-----
|
|
2
|
+
MIGkAgEBBDBQJuwafREZ1494Fm2MTVXuZbWXVAOwIAxGhyLdc3CChzi0FVXZq8e6
|
|
3
|
+
65oR0Qq9Jv2gBwYFK4EEACKhZANiAAQWFddzIqZaROR1VtZhhTd20mqknQmYsZ+0
|
|
4
|
+
R03NQQUQpJTkyWcuv8WNyd6zO9cCoQEzi94kX907/OEWTjhuH8QtdunT+ef1BpWJ
|
|
5
|
+
W1Cm5O+m7b155/Ho99QypfQr74hLg1A=
|
|
6
|
+
-----END EC PRIVATE KEY-----
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
uOSJMhbKSG4V5xUHS7B9YHmVg/1yVd+G+Io6oBFhSfY=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
i4eTKkWNIISKumdk3v90cPDrY/g8WRTJWy7DmGDsdzC45IkyFspIbhXnFQdLsH1geZWD/XJV34b4ijqgEWFJ9g==
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
{
|
|
2
|
+
"keys": [
|
|
3
|
+
{
|
|
4
|
+
"kty": "RSA",
|
|
5
|
+
"e": "AQAB",
|
|
6
|
+
"kid": "jwk1",
|
|
7
|
+
"n": "0Ttga33B1yX4w77NbpKyNYDNSVCo8j-RlZaZ9tI-KfkV1d-tfsvI9ZPAheP11FoN52ceBaY5ltelHW-IKwCfyT0orLdsxLgowaXki9woF1Azvcg2JVxQLv9aVjjAvy3CZFIG_EeN7J3nsyCXGnu1yMEbnvkWxA88__Q6HQ2K9wqfApkQ0LNlsK0YHz_sfjHNvRKxnbAJk7D5fUhZunPZXOPHXFgA5SvLvMaNIXduMKJh4OMfuoLdJowXJAR9j31Mqz_is4FMhm_9Mq7vZZ-uF09htRvIR8tRY28oJuW1gKWyg7cQQpnjHgFyG3XLXWAeXclWqyh_LfjyHQjrYhyeFw",
|
|
8
|
+
"alg": "RS256"
|
|
9
|
+
},
|
|
10
|
+
{
|
|
11
|
+
"kty": "RSA",
|
|
12
|
+
"e": "AQAB",
|
|
13
|
+
"kid": "jwk2",
|
|
14
|
+
"n": "pXi2o6AnNhwL30MaK_nuDHi2fxZHVen7Xwk0bjLGlHYpq3mSvXm2HBA-zR41vQCbHkYGsDpsyDhIXLBDTbSa7ue7D1ZqYdv5YLIS33zdX9GtUHfFHc6zYgXAU9ziWeyTzVn7icAbjxqcgT2xKNuGK7Zf2ZJ053rr-dxjAE-SjX4SG0WWUhwPjxlr1etF7mEurhHweuSdZYl36g39o9BtTBVfS87io2MwdIRsnL3w8ulgXRVRWjv-vvcuhMS_y6zGbzOC55Yr23sb4h2PSll32bgyglEIsGgHqjOdyjuUzl0t6jh86DHzbu9h-u1iihX8EI8t7CBbizbPPyHQygp-rQ",
|
|
15
|
+
"alg": "RS256"
|
|
16
|
+
}
|
|
17
|
+
]
|
|
18
|
+
}
|