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,234 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
declare(strict_types=1);
|
|
4
|
+
|
|
5
|
+
namespace Dotenv\Tests\Parser;
|
|
6
|
+
|
|
7
|
+
use Dotenv\Parser\Entry;
|
|
8
|
+
use Dotenv\Parser\EntryParser;
|
|
9
|
+
use Dotenv\Parser\Value;
|
|
10
|
+
use GrahamCampbell\ResultType\Result;
|
|
11
|
+
use PHPUnit\Framework\TestCase;
|
|
12
|
+
|
|
13
|
+
final class EntryParserTest extends TestCase
|
|
14
|
+
{
|
|
15
|
+
public function testBasicParse()
|
|
16
|
+
{
|
|
17
|
+
$result = EntryParser::parse('FOO=BAR');
|
|
18
|
+
$this->checkPositiveResult($result, 'FOO', 'BAR');
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
public function testNullParse()
|
|
22
|
+
{
|
|
23
|
+
$result = EntryParser::parse('FOO');
|
|
24
|
+
$this->checkEmptyResult($result, 'FOO');
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
public function testUnicodeNameParse()
|
|
28
|
+
{
|
|
29
|
+
$result = EntryParser::parse('FOOƱ=BAZ');
|
|
30
|
+
$this->checkPositiveResult($result, 'FOOƱ', 'BAZ');
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
public function testQuotesParse()
|
|
34
|
+
{
|
|
35
|
+
$result = EntryParser::parse("FOO=\"BAR \n\"");
|
|
36
|
+
$this->checkPositiveResult($result, 'FOO', "BAR \n");
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
public function testNewlineParse()
|
|
40
|
+
{
|
|
41
|
+
$result = EntryParser::parse('FOO="\n"');
|
|
42
|
+
$this->checkPositiveResult($result, 'FOO', "\n");
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
public function testTabParseDouble()
|
|
46
|
+
{
|
|
47
|
+
$result = EntryParser::parse('FOO="\t"');
|
|
48
|
+
$this->checkPositiveResult($result, 'FOO', "\t");
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
public function testTabParseSingle()
|
|
52
|
+
{
|
|
53
|
+
$result = EntryParser::parse('FOO=\'\t\'');
|
|
54
|
+
$this->checkPositiveResult($result, 'FOO', '\t');
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
public function testNonEscapeParse1()
|
|
58
|
+
{
|
|
59
|
+
$result = EntryParser::parse('FOO=\n\v');
|
|
60
|
+
$this->checkPositiveResult($result, 'FOO', '\n\v');
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
public function testNonEscapeParse2()
|
|
64
|
+
{
|
|
65
|
+
$result = EntryParser::parse('FOO=\q');
|
|
66
|
+
$this->checkPositiveResult($result, 'FOO', '\q');
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
public function testBadEscapeParse()
|
|
70
|
+
{
|
|
71
|
+
$result = EntryParser::parse('FOO="\q"');
|
|
72
|
+
$this->checkErrorResult($result, 'Encountered an unexpected escape sequence at ["\q"].');
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
public function testInlineVariable()
|
|
76
|
+
{
|
|
77
|
+
$result = EntryParser::parse('FOO=$BAR');
|
|
78
|
+
$this->checkPositiveResult($result, 'FOO', '$BAR', [0]);
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
public function testInlineVariableOffset()
|
|
82
|
+
{
|
|
83
|
+
$result = EntryParser::parse('FOO=AAA$BAR');
|
|
84
|
+
$this->checkPositiveResult($result, 'FOO', 'AAA$BAR', [3]);
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
public function testInlineVariables()
|
|
88
|
+
{
|
|
89
|
+
$result = EntryParser::parse('FOO="TEST $BAR $$BAZ"');
|
|
90
|
+
$this->checkPositiveResult($result, 'FOO', 'TEST $BAR $$BAZ', [11, 10, 5]);
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
public function testNonInlineVariable()
|
|
94
|
+
{
|
|
95
|
+
$result = EntryParser::parse('FOO=\'TEST $BAR $$BAZ\'');
|
|
96
|
+
$this->checkPositiveResult($result, 'FOO', 'TEST $BAR $$BAZ');
|
|
97
|
+
self::assertTrue($result->success()->isDefined());
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
public function testWhitespaceParse()
|
|
101
|
+
{
|
|
102
|
+
$result = EntryParser::parse("FOO=\"\n\"");
|
|
103
|
+
$this->checkPositiveResult($result, 'FOO', "\n");
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
public function testExportParse()
|
|
107
|
+
{
|
|
108
|
+
$result = EntryParser::parse('export FOO="bar baz"');
|
|
109
|
+
$this->checkPositiveResult($result, 'FOO', 'bar baz');
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
public function testExportParseTab()
|
|
113
|
+
{
|
|
114
|
+
$result = EntryParser::parse("export\t\"FOO\"='bar baz'");
|
|
115
|
+
$this->checkPositiveResult($result, 'FOO', 'bar baz');
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
public function testExportParseFail()
|
|
119
|
+
{
|
|
120
|
+
$result = EntryParser::parse('export "FOO="bar baz"');
|
|
121
|
+
$this->checkErrorResult($result, 'Encountered an invalid name at ["FOO].');
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
public function testClosingSlashParse()
|
|
125
|
+
{
|
|
126
|
+
$result = EntryParser::parse('SPVAR5="test some escaped characters like a quote \\" or maybe a backslash \\\\" # not escaped');
|
|
127
|
+
$this->checkPositiveResult($result, 'SPVAR5', 'test some escaped characters like a quote " or maybe a backslash \\');
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
public function testParseInvalidSpaces()
|
|
131
|
+
{
|
|
132
|
+
$result = EntryParser::parse('FOO=bar baz');
|
|
133
|
+
$this->checkErrorResult($result, 'Encountered unexpected whitespace at [bar baz].');
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
public function testParseStrayEquals()
|
|
137
|
+
{
|
|
138
|
+
$result = EntryParser::parse('=');
|
|
139
|
+
$this->checkErrorResult($result, 'Encountered an unexpected equals at [=].');
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
public function testParseInvalidName()
|
|
143
|
+
{
|
|
144
|
+
$result = EntryParser::parse('FOO_ASD!=BAZ');
|
|
145
|
+
$this->checkErrorResult($result, 'Encountered an invalid name at [FOO_ASD!].');
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
public function testParserEscapingDouble()
|
|
149
|
+
{
|
|
150
|
+
$result = EntryParser::parse('FOO_BAD="iiiiviiiixiiiiviiii\\a"');
|
|
151
|
+
$this->checkErrorResult($result, 'Encountered an unexpected escape sequence at ["iiiiviiiixiiiiviiii\a"].');
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
public function testParserEscapingSingle()
|
|
155
|
+
{
|
|
156
|
+
$result = EntryParser::parse('FOO_BAD=\'iiiiviiiixiiiiviiii\\a\'');
|
|
157
|
+
$this->checkPositiveResult($result, 'FOO_BAD', 'iiiiviiiixiiiiviiii\\a');
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
public function testParserMissingClosingSingleQuote()
|
|
161
|
+
{
|
|
162
|
+
$result = EntryParser::parse('TEST=\'erert');
|
|
163
|
+
$this->checkErrorResult($result, 'Encountered a missing closing quote at [\'erert].');
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
public function testParserMissingClosingDoubleQuote()
|
|
167
|
+
{
|
|
168
|
+
$result = EntryParser::parse('TEST="erert');
|
|
169
|
+
$this->checkErrorResult($result, 'Encountered a missing closing quote at ["erert].');
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
public function testParserMissingClosingQuotes()
|
|
173
|
+
{
|
|
174
|
+
$result = EntryParser::parse("TEST=\"erert\nTEST='erert\n");
|
|
175
|
+
$this->checkErrorResult($result, 'Encountered a missing closing quote at ["erert].');
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
public function testParserClosingQuoteWithEscape()
|
|
179
|
+
{
|
|
180
|
+
$result = EntryParser::parse('TEST="\\');
|
|
181
|
+
$this->checkErrorResult($result, 'Encountered a missing closing quote at ["\\].');
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
/**
|
|
185
|
+
* @param \GrahamCampbell\ResultType\Result<\Dotenv\Parser\Entry,string> $result
|
|
186
|
+
* @param string $name
|
|
187
|
+
* @param string $chars
|
|
188
|
+
* @param int[] $vars
|
|
189
|
+
*
|
|
190
|
+
* @return void
|
|
191
|
+
*/
|
|
192
|
+
private function checkPositiveResult(Result $result, string $name, string $chars, array $vars = [])
|
|
193
|
+
{
|
|
194
|
+
self::assertTrue($result->success()->isDefined());
|
|
195
|
+
|
|
196
|
+
$entry = $result->success()->get();
|
|
197
|
+
self::assertInstanceOf(Entry::class, $entry);
|
|
198
|
+
self::assertSame($name, $entry->getName());
|
|
199
|
+
self::assertTrue($entry->getValue()->isDefined());
|
|
200
|
+
|
|
201
|
+
$value = $entry->getValue()->get();
|
|
202
|
+
self::assertInstanceOf(Value::class, $value);
|
|
203
|
+
self::assertSame($chars, $value->getChars());
|
|
204
|
+
self::assertSame($vars, $value->getVars());
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
/**
|
|
208
|
+
* @param \GrahamCampbell\ResultType\Result<\Dotenv\Parser\Entry,string> $result
|
|
209
|
+
* @param string $name
|
|
210
|
+
*
|
|
211
|
+
* @return void
|
|
212
|
+
*/
|
|
213
|
+
private function checkEmptyResult(Result $result, string $name)
|
|
214
|
+
{
|
|
215
|
+
self::assertTrue($result->success()->isDefined());
|
|
216
|
+
|
|
217
|
+
$entry = $result->success()->get();
|
|
218
|
+
self::assertInstanceOf(Entry::class, $entry);
|
|
219
|
+
self::assertSame('FOO', $entry->getName());
|
|
220
|
+
self::assertFalse($entry->getValue()->isDefined());
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
/**
|
|
224
|
+
* @param \GrahamCampbell\ResultType\Result<\Dotenv\Parser\Entry,string> $result
|
|
225
|
+
* @param string $error
|
|
226
|
+
*
|
|
227
|
+
* @return void
|
|
228
|
+
*/
|
|
229
|
+
private function checkErrorResult(Result $result, string $error)
|
|
230
|
+
{
|
|
231
|
+
self::assertTrue($result->error()->isDefined());
|
|
232
|
+
self::assertSame($error, $result->error()->get());
|
|
233
|
+
}
|
|
234
|
+
}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
declare(strict_types=1);
|
|
4
|
+
|
|
5
|
+
namespace Dotenv\Tests\Parser;
|
|
6
|
+
|
|
7
|
+
use Dotenv\Parser\Lexer;
|
|
8
|
+
use PHPUnit\Framework\TestCase;
|
|
9
|
+
|
|
10
|
+
final class LexerTest extends TestCase
|
|
11
|
+
{
|
|
12
|
+
/**
|
|
13
|
+
* @return array{string,string[]}[]
|
|
14
|
+
*/
|
|
15
|
+
public static function provideLexCases()
|
|
16
|
+
{
|
|
17
|
+
return [
|
|
18
|
+
['', []],
|
|
19
|
+
['FOO', ['FOO']],
|
|
20
|
+
['FOO bar', ['FOO', ' ', 'bar']],
|
|
21
|
+
['FOO\\n()ab', ['FOO', '\\', 'n()ab']],
|
|
22
|
+
["FOO\n\n A", ['FOO', "\n\n", ' ', 'A']],
|
|
23
|
+
['"VA=L"', ['"', 'VA=L', '"']],
|
|
24
|
+
['\' \'', ['\'', ' ', '\'']],
|
|
25
|
+
];
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* @dataProvider provideLexCases
|
|
30
|
+
*
|
|
31
|
+
* @param string $input
|
|
32
|
+
* @param string[] $output
|
|
33
|
+
*
|
|
34
|
+
* @return void
|
|
35
|
+
*/
|
|
36
|
+
public function testLex(string $input, array $output)
|
|
37
|
+
{
|
|
38
|
+
self::assertSame($output, \iterator_to_array(Lexer::lex($input)));
|
|
39
|
+
}
|
|
40
|
+
}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
declare(strict_types=1);
|
|
4
|
+
|
|
5
|
+
namespace Dotenv\Tests\Parser;
|
|
6
|
+
|
|
7
|
+
use Dotenv\Parser\Lines;
|
|
8
|
+
use Dotenv\Util\Regex;
|
|
9
|
+
use PHPUnit\Framework\TestCase;
|
|
10
|
+
|
|
11
|
+
final class LinesTest extends TestCase
|
|
12
|
+
{
|
|
13
|
+
public function testProcessBasic()
|
|
14
|
+
{
|
|
15
|
+
$content = \file_get_contents(\dirname(\dirname(__DIR__)).'/fixtures/env/assertions.env');
|
|
16
|
+
self::assertIsString($content);
|
|
17
|
+
$result = Regex::split("/(\r\n|\n|\r)/", $content);
|
|
18
|
+
self::assertTrue($result->success()->isDefined());
|
|
19
|
+
|
|
20
|
+
$expected = [
|
|
21
|
+
'ASSERTVAR1=val1',
|
|
22
|
+
'ASSERTVAR2=""',
|
|
23
|
+
'ASSERTVAR3="val3 "',
|
|
24
|
+
'ASSERTVAR4="0" # empty looking value',
|
|
25
|
+
'ASSERTVAR5="#foo"',
|
|
26
|
+
"ASSERTVAR6=\"val1\nval2\"",
|
|
27
|
+
"ASSERTVAR7=\"\nval3\" #",
|
|
28
|
+
"ASSERTVAR8=\"val3\n\"",
|
|
29
|
+
"ASSERTVAR9=\"\n\n\"",
|
|
30
|
+
];
|
|
31
|
+
|
|
32
|
+
self::assertSame($expected, Lines::process($result->success()->get()));
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
public function testProcessQuotes()
|
|
36
|
+
{
|
|
37
|
+
$content = \file_get_contents(\dirname(\dirname(__DIR__)).'/fixtures/env/multiline.env');
|
|
38
|
+
self::assertIsString($content);
|
|
39
|
+
$result = Regex::split("/(\r\n|\n|\r)/", $content);
|
|
40
|
+
self::assertTrue($result->success()->isDefined());
|
|
41
|
+
|
|
42
|
+
$expected = [
|
|
43
|
+
"TEST=\"test\n test\\\"test\\\"\n test\"",
|
|
44
|
+
'TEST_ND="test\\ntest"',
|
|
45
|
+
'TEST_NS=\'test\\ntest\'',
|
|
46
|
+
'TEST_EQD="https://vision.googleapis.com/v1/images:annotate?key="',
|
|
47
|
+
'TEST_EQS=\'https://vision.googleapis.com/v1/images:annotate?key=\'',
|
|
48
|
+
"BASE64_ENCODED_MULTILINE=\"qS1zCzMVVUJWQShokv6YVYi+ruKSC/bHV7GmEiyVkLaBWJHNVHCHsgTksEBsy8wJ\nuwycAvR07ZyOJJed4XTRMKnKp1/v+6UATpWzkIjZXytK+pD+XlZimUHTx3uiDcmU\njhQX1wWSxHDqrSWxeIJiTD+BuUyId8FzmXQ3TcBydJ474tmOU2F492ubk3LAiZ18\nmhiRGoshXAOSbS/P3+RZi4bDeNE/No4=\"",
|
|
49
|
+
];
|
|
50
|
+
|
|
51
|
+
self::assertSame($expected, Lines::process($result->success()->get()));
|
|
52
|
+
}
|
|
53
|
+
}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
declare(strict_types=1);
|
|
4
|
+
|
|
5
|
+
namespace Dotenv\Tests\Parser;
|
|
6
|
+
|
|
7
|
+
use Dotenv\Exception\InvalidFileException;
|
|
8
|
+
use Dotenv\Parser\Entry;
|
|
9
|
+
use Dotenv\Parser\Parser;
|
|
10
|
+
use Dotenv\Parser\ParserInterface;
|
|
11
|
+
use Dotenv\Parser\Value;
|
|
12
|
+
use PHPUnit\Framework\TestCase;
|
|
13
|
+
|
|
14
|
+
final class ParserTest extends TestCase
|
|
15
|
+
{
|
|
16
|
+
public function testParserInstanceOf()
|
|
17
|
+
{
|
|
18
|
+
self::assertInstanceOf(ParserInterface::class, new Parser());
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
public function testFullParse()
|
|
22
|
+
{
|
|
23
|
+
$result = (new Parser())->parse("FOO=BAR\nFOO\nFOO=\"BAR \n\"\nFOO=\"\\n\"");
|
|
24
|
+
|
|
25
|
+
self::assertIsArray($result);
|
|
26
|
+
self::assertCount(4, $result);
|
|
27
|
+
|
|
28
|
+
$this->checkPositiveEntry($result[0], 'FOO', 'BAR');
|
|
29
|
+
$this->checkEmptyEntry($result[1], 'FOO');
|
|
30
|
+
$this->checkPositiveEntry($result[2], 'FOO', "BAR \n");
|
|
31
|
+
$this->checkPositiveEntry($result[3], 'FOO', "\n");
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
public function testBadEscapeParse()
|
|
35
|
+
{
|
|
36
|
+
$this->expectException(InvalidFileException::class);
|
|
37
|
+
$this->expectExceptionMessage('Failed to parse dotenv file. Encountered an unexpected escape sequence at ["\q"].');
|
|
38
|
+
|
|
39
|
+
(new Parser())->parse('FOO="\q"');
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
public function testParseInvalidSpaces()
|
|
43
|
+
{
|
|
44
|
+
$this->expectException(InvalidFileException::class);
|
|
45
|
+
$this->expectExceptionMessage('Failed to parse dotenv file. Encountered unexpected whitespace at [bar baz].');
|
|
46
|
+
|
|
47
|
+
(new Parser())->parse("FOO=bar baz\n");
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
public function testParseStrayEquals()
|
|
51
|
+
{
|
|
52
|
+
$this->expectException(InvalidFileException::class);
|
|
53
|
+
$this->expectExceptionMessage('Failed to parse dotenv file. Encountered an unexpected equals at [=].');
|
|
54
|
+
|
|
55
|
+
(new Parser())->parse("=\n");
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
public function testParseInvalidName()
|
|
59
|
+
{
|
|
60
|
+
$this->expectException(InvalidFileException::class);
|
|
61
|
+
$this->expectExceptionMessage('Failed to parse dotenv file. Encountered an invalid name at [FOO_ASD!].');
|
|
62
|
+
|
|
63
|
+
(new Parser())->parse('FOO_ASD!=BAZ');
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
/**
|
|
67
|
+
* @param \Dotenv\Parser\Entry $entry
|
|
68
|
+
* @param string $name
|
|
69
|
+
* @param string $chars
|
|
70
|
+
* @param int[] $vars
|
|
71
|
+
*
|
|
72
|
+
* @return void
|
|
73
|
+
*/
|
|
74
|
+
private function checkPositiveEntry(Entry $entry, string $name, string $chars, array $vars = [])
|
|
75
|
+
{
|
|
76
|
+
self::assertInstanceOf(Entry::class, $entry);
|
|
77
|
+
self::assertSame($name, $entry->getName());
|
|
78
|
+
self::assertTrue($entry->getValue()->isDefined());
|
|
79
|
+
|
|
80
|
+
$value = $entry->getValue()->get();
|
|
81
|
+
self::assertInstanceOf(Value::class, $value);
|
|
82
|
+
self::assertSame($chars, $value->getChars());
|
|
83
|
+
self::assertSame($vars, $value->getVars());
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
/**
|
|
87
|
+
* @param \Dotenv\Parser\Entry $entry
|
|
88
|
+
* @param string $name
|
|
89
|
+
*
|
|
90
|
+
* @return void
|
|
91
|
+
*/
|
|
92
|
+
private function checkEmptyEntry(Entry $entry, string $name)
|
|
93
|
+
{
|
|
94
|
+
self::assertInstanceOf(Entry::class, $entry);
|
|
95
|
+
self::assertSame('FOO', $entry->getName());
|
|
96
|
+
self::assertFalse($entry->getValue()->isDefined());
|
|
97
|
+
}
|
|
98
|
+
}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
declare(strict_types=1);
|
|
4
|
+
|
|
5
|
+
namespace Dotenv\Tests\Repository\Adapter;
|
|
6
|
+
|
|
7
|
+
use Dotenv\Repository\Adapter\ArrayAdapter;
|
|
8
|
+
use PHPUnit\Framework\TestCase;
|
|
9
|
+
|
|
10
|
+
final class ArrayAdapterTest extends TestCase
|
|
11
|
+
{
|
|
12
|
+
public function testGoodRead()
|
|
13
|
+
{
|
|
14
|
+
$adapter = self::createAdapter();
|
|
15
|
+
$adapter->write('CONST_TEST', 'foo bar baz');
|
|
16
|
+
$value = $adapter->read('CONST_TEST');
|
|
17
|
+
self::assertTrue($value->isDefined());
|
|
18
|
+
self::assertSame('foo bar baz', $value->get());
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
public function testUndefinedRead()
|
|
22
|
+
{
|
|
23
|
+
$adapter = self::createAdapter();
|
|
24
|
+
unset($_ENV['CONST_TEST']);
|
|
25
|
+
$value = $adapter->read('CONST_TEST');
|
|
26
|
+
self::assertFalse($value->isDefined());
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
public function testGoodWrite()
|
|
30
|
+
{
|
|
31
|
+
$adapter = self::createAdapter();
|
|
32
|
+
self::assertTrue($adapter->write('CONST_TEST', 'foo'));
|
|
33
|
+
self::assertSame('foo', $adapter->read('CONST_TEST')->get());
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
public function testEmptyWrite()
|
|
37
|
+
{
|
|
38
|
+
$adapter = self::createAdapter();
|
|
39
|
+
self::assertTrue($adapter->write('CONST_TEST', ''));
|
|
40
|
+
self::assertSame('', $adapter->read('CONST_TEST')->get());
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
public function testGoodDelete()
|
|
44
|
+
{
|
|
45
|
+
$adapter = self::createAdapter();
|
|
46
|
+
self::assertTrue($adapter->delete('CONST_TEST'));
|
|
47
|
+
self::assertFalse($adapter->read('CONST_TEST')->isDefined());
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* @return \Dotenv\Repository\Adapter\AdapterInterface
|
|
52
|
+
*/
|
|
53
|
+
private static function createAdapter()
|
|
54
|
+
{
|
|
55
|
+
return ArrayAdapter::create()->get();
|
|
56
|
+
}
|
|
57
|
+
}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
declare(strict_types=1);
|
|
4
|
+
|
|
5
|
+
namespace Dotenv\Tests\Repository\Adapter;
|
|
6
|
+
|
|
7
|
+
use Dotenv\Repository\Adapter\EnvConstAdapter;
|
|
8
|
+
use PHPUnit\Framework\TestCase;
|
|
9
|
+
|
|
10
|
+
final class EnvConstAdapterTest extends TestCase
|
|
11
|
+
{
|
|
12
|
+
public function testGoodRead()
|
|
13
|
+
{
|
|
14
|
+
$_ENV['CONST_TEST'] = 'foo bar baz';
|
|
15
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
16
|
+
self::assertTrue($value->isDefined());
|
|
17
|
+
self::assertSame('foo bar baz', $value->get());
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
public function testFalseRead()
|
|
21
|
+
{
|
|
22
|
+
$_ENV['CONST_TEST'] = false;
|
|
23
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
24
|
+
self::assertTrue($value->isDefined());
|
|
25
|
+
self::assertSame('false', $value->get());
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
public function testTrueRead()
|
|
29
|
+
{
|
|
30
|
+
$_ENV['CONST_TEST'] = true;
|
|
31
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
32
|
+
self::assertTrue($value->isDefined());
|
|
33
|
+
self::assertSame('true', $value->get());
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
public function testBadTypeRead()
|
|
37
|
+
{
|
|
38
|
+
$_ENV['CONST_TEST'] = [123];
|
|
39
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
40
|
+
self::assertFalse($value->isDefined());
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
public function testUndefinedRead()
|
|
44
|
+
{
|
|
45
|
+
unset($_ENV['CONST_TEST']);
|
|
46
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
47
|
+
self::assertFalse($value->isDefined());
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
public function testGoodWrite()
|
|
51
|
+
{
|
|
52
|
+
self::assertTrue(self::createAdapter()->write('CONST_TEST', 'foo'));
|
|
53
|
+
self::assertSame('foo', $_ENV['CONST_TEST']);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
public function testEmptyWrite()
|
|
57
|
+
{
|
|
58
|
+
self::assertTrue(self::createAdapter()->write('CONST_TEST', ''));
|
|
59
|
+
self::assertSame('', $_ENV['CONST_TEST']);
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
public function testGoodDelete()
|
|
63
|
+
{
|
|
64
|
+
self::assertTrue(self::createAdapter()->delete('CONST_TEST'));
|
|
65
|
+
self::assertFalse(isset($_ENV['CONST_TEST']));
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
* @return \Dotenv\Repository\Adapter\AdapterInterface
|
|
70
|
+
*/
|
|
71
|
+
private static function createAdapter()
|
|
72
|
+
{
|
|
73
|
+
return EnvConstAdapter::create()->get();
|
|
74
|
+
}
|
|
75
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
declare(strict_types=1);
|
|
4
|
+
|
|
5
|
+
namespace Dotenv\Tests\Repository\Adapter;
|
|
6
|
+
|
|
7
|
+
use Dotenv\Repository\Adapter\PutenvAdapter;
|
|
8
|
+
use PHPUnit\Framework\TestCase;
|
|
9
|
+
|
|
10
|
+
final class PutenvAdapterTest extends TestCase
|
|
11
|
+
{
|
|
12
|
+
public function testGoodRead()
|
|
13
|
+
{
|
|
14
|
+
\putenv('CONST_TEST=foo bar baz');
|
|
15
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
16
|
+
self::assertTrue($value->isDefined());
|
|
17
|
+
self::assertSame('foo bar baz', $value->get());
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
public function testUndefinedRead()
|
|
21
|
+
{
|
|
22
|
+
\putenv('CONST_TEST');
|
|
23
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
24
|
+
self::assertFalse($value->isDefined());
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
public function testGoodWrite()
|
|
28
|
+
{
|
|
29
|
+
self::assertTrue(self::createAdapter()->write('CONST_TEST', 'foo'));
|
|
30
|
+
self::assertSame('foo', \getenv('CONST_TEST'));
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
public function testEmptyWrite()
|
|
34
|
+
{
|
|
35
|
+
self::assertTrue(self::createAdapter()->write('CONST_TEST', ''));
|
|
36
|
+
self::assertSame('', \getenv('CONST_TEST'));
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
public function testGoodDelete()
|
|
40
|
+
{
|
|
41
|
+
self::assertTrue(self::createAdapter()->delete('CONST_TEST'));
|
|
42
|
+
self::assertFalse(\getenv('CONST_TEST'));
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* @return \Dotenv\Repository\Adapter\AdapterInterface
|
|
47
|
+
*/
|
|
48
|
+
private static function createAdapter()
|
|
49
|
+
{
|
|
50
|
+
return PutenvAdapter::create()->get();
|
|
51
|
+
}
|
|
52
|
+
}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
declare(strict_types=1);
|
|
4
|
+
|
|
5
|
+
namespace Dotenv\Tests\Repository\Adapter;
|
|
6
|
+
|
|
7
|
+
use Dotenv\Repository\Adapter\ServerConstAdapter;
|
|
8
|
+
use PHPUnit\Framework\TestCase;
|
|
9
|
+
|
|
10
|
+
final class ServerConstAdapterTest extends TestCase
|
|
11
|
+
{
|
|
12
|
+
public function testGoodRead()
|
|
13
|
+
{
|
|
14
|
+
$_SERVER['CONST_TEST'] = 'foo bar baz';
|
|
15
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
16
|
+
self::assertTrue($value->isDefined());
|
|
17
|
+
self::assertSame('foo bar baz', $value->get());
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
public function testFalseRead()
|
|
21
|
+
{
|
|
22
|
+
$_SERVER['CONST_TEST'] = false;
|
|
23
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
24
|
+
self::assertTrue($value->isDefined());
|
|
25
|
+
self::assertSame('false', $value->get());
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
public function testTrueRead()
|
|
29
|
+
{
|
|
30
|
+
$_SERVER['CONST_TEST'] = true;
|
|
31
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
32
|
+
self::assertTrue($value->isDefined());
|
|
33
|
+
self::assertSame('true', $value->get());
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
public function testBadTypeRead()
|
|
37
|
+
{
|
|
38
|
+
$_SERVER['CONST_TEST'] = [123];
|
|
39
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
40
|
+
self::assertFalse($value->isDefined());
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
public function testUndefinedRead()
|
|
44
|
+
{
|
|
45
|
+
unset($_SERVER['CONST_TEST']);
|
|
46
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
47
|
+
self::assertFalse($value->isDefined());
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
public function testGoodWrite()
|
|
51
|
+
{
|
|
52
|
+
self::assertTrue(self::createAdapter()->write('CONST_TEST', 'foo'));
|
|
53
|
+
self::assertSame('foo', $_SERVER['CONST_TEST']);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
public function testEmptyWrite()
|
|
57
|
+
{
|
|
58
|
+
self::assertTrue(self::createAdapter()->write('CONST_TEST', ''));
|
|
59
|
+
self::assertSame('', $_SERVER['CONST_TEST']);
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
public function testGoodDelete()
|
|
63
|
+
{
|
|
64
|
+
self::assertTrue(self::createAdapter()->delete('CONST_TEST'));
|
|
65
|
+
self::assertFalse(isset($_SERVER['CONST_TEST']));
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
* @return \Dotenv\Repository\Adapter\AdapterInterface
|
|
70
|
+
*/
|
|
71
|
+
private static function createAdapter()
|
|
72
|
+
{
|
|
73
|
+
return ServerConstAdapter::create()->get();
|
|
74
|
+
}
|
|
75
|
+
}
|