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,59 @@
|
|
|
1
|
+
language: php
|
|
2
|
+
sudo: false
|
|
3
|
+
|
|
4
|
+
matrix:
|
|
5
|
+
fast_finish: true
|
|
6
|
+
include:
|
|
7
|
+
- dist: precise
|
|
8
|
+
php: "5.3"
|
|
9
|
+
env: USE_PSALM=0
|
|
10
|
+
CHECK_MBSTRING=1
|
|
11
|
+
- dist: precise
|
|
12
|
+
php: "5.4"
|
|
13
|
+
env: USE_PSALM=0
|
|
14
|
+
CHECK_MBSTRING=1
|
|
15
|
+
- dist: precise
|
|
16
|
+
php: "5.5"
|
|
17
|
+
env: USE_PSALM=0
|
|
18
|
+
CHECK_MBSTRING=1
|
|
19
|
+
- dist: precise
|
|
20
|
+
php: "5.6"
|
|
21
|
+
env: USE_PSALM=1
|
|
22
|
+
CHECK_MBSTRING=1
|
|
23
|
+
- php: "7.0"
|
|
24
|
+
env: USE_PSALM=1
|
|
25
|
+
CHECK_MBSTRING=1
|
|
26
|
+
- php: "7.1"
|
|
27
|
+
env: USE_PSALM=1
|
|
28
|
+
CHECK_MBSTRING=1
|
|
29
|
+
- php: "7.2"
|
|
30
|
+
env: USE_PSALM=1
|
|
31
|
+
CHECK_MBSTRING=0
|
|
32
|
+
- php: "7.3"
|
|
33
|
+
env: USE_PSALM=1
|
|
34
|
+
CHECK_MBSTRING=0
|
|
35
|
+
- php: "7.4"
|
|
36
|
+
env: USE_PSALM=1
|
|
37
|
+
CHECK_MBSTRING=0
|
|
38
|
+
- php: "nightly"
|
|
39
|
+
env: USE_PSALM=1
|
|
40
|
+
CHECK_MBSTRING=0
|
|
41
|
+
- php: "hhvm"
|
|
42
|
+
env: USE_PSALM=1
|
|
43
|
+
CHECK_MBSTRING=1
|
|
44
|
+
- php: "master"
|
|
45
|
+
env: USE_PSALM=1
|
|
46
|
+
CHECK_MBSTRING=0
|
|
47
|
+
allow_failures:
|
|
48
|
+
- php: "hhvm"
|
|
49
|
+
- php: "master"
|
|
50
|
+
|
|
51
|
+
install:
|
|
52
|
+
- composer self-update
|
|
53
|
+
- composer install
|
|
54
|
+
- if [[ $USE_PSALM -eq 1 ]]; then composer require --dev "vimeo/psalm:^0|^1|^2"; fi
|
|
55
|
+
|
|
56
|
+
script:
|
|
57
|
+
- vendor/bin/phpunit
|
|
58
|
+
- php -dmbstring.func_overload=7 vendor/bin/phpunit
|
|
59
|
+
- if [[ $USE_PSALM -eq 1 ]]; then vendor/bin/psalm; fi
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
The MIT License (MIT)
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2015 Paragon Initiative Enterprises
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
|
22
|
+
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
## Rationale (Design Decisions)
|
|
2
|
+
|
|
3
|
+
### Reasoning Behind the Order of Preferred Random Data Sources
|
|
4
|
+
|
|
5
|
+
The order is:
|
|
6
|
+
|
|
7
|
+
1. `libsodium if available`
|
|
8
|
+
2. `fread() /dev/urandom if available`
|
|
9
|
+
3. `mcrypt_create_iv($bytes, MCRYPT_DEV_URANDOM)`
|
|
10
|
+
4. `COM('CAPICOM.Utilities.1')->GetRandom()`
|
|
11
|
+
|
|
12
|
+
If libsodium is available, we get random data from it. This is the preferred
|
|
13
|
+
method on all OSes, but libsodium is not very widely installed, so other
|
|
14
|
+
fallbacks are available.
|
|
15
|
+
|
|
16
|
+
Next, we read `/dev/urandom` (if it exists). This is the preferred file to read
|
|
17
|
+
for random data for cryptographic purposes for BSD and Linux. This step
|
|
18
|
+
is skipped on Windows, because someone could create a `C:\dev\urandom`
|
|
19
|
+
file and PHP would helpfully (but insecurely) return bytes from it.
|
|
20
|
+
|
|
21
|
+
Despite [strongly urging people not to use mcrypt in their projects](https://paragonie.com/blog/2015/05/if-you-re-typing-word-mcrypt-into-your-code-you-re-doing-it-wrong)
|
|
22
|
+
(because libmcrypt is abandonware and the API puts too much responsibility on the
|
|
23
|
+
implementor) we prioritize `mcrypt_create_iv()` with `MCRYPT_DEV_URANDOM` above
|
|
24
|
+
the remaining implementations.
|
|
25
|
+
|
|
26
|
+
The reason is simple: `mcrypt_create_iv()` is part of PHP's `ext/mcrypt` code,
|
|
27
|
+
and is not part `libmcrypt`. It actually does the right thing:
|
|
28
|
+
|
|
29
|
+
* On Unix-based operating systems, it reads from `/dev/urandom` which
|
|
30
|
+
(unlike `/dev/random`) is the sane and correct thing to do.
|
|
31
|
+
* On Windows, it reads from `CryptGenRandom`, which is an exclusively Windows
|
|
32
|
+
way to get random bytes.
|
|
33
|
+
|
|
34
|
+
If we're on Windows and don't have access to `mcrypt`, we use `CAPICOM.Utilities.1`.
|
|
35
|
+
|
|
36
|
+
As of random_compat 2.0, we no longer fall through to OpenSSL.
|
|
@@ -0,0 +1,232 @@
|
|
|
1
|
+
# random_compat
|
|
2
|
+
|
|
3
|
+
[](https://travis-ci.org/paragonie/random_compat)
|
|
4
|
+
[](https://scrutinizer-ci.com/g/paragonie/random_compat)
|
|
5
|
+
[](https://packagist.org/packages/paragonie/random_compat)
|
|
6
|
+
[](https://packagist.org/packages/paragonie/random_compat)
|
|
7
|
+
[](https://packagist.org/packages/paragonie/random_compat)
|
|
8
|
+
[](https://packagist.org/packages/paragonie/random_compat)
|
|
9
|
+
|
|
10
|
+
PHP 5.x polyfill for `random_bytes()` and `random_int()` created and maintained
|
|
11
|
+
by [Paragon Initiative Enterprises](https://paragonie.com).
|
|
12
|
+
|
|
13
|
+
Although this library *should* function in earlier versions of PHP, we will only
|
|
14
|
+
consider issues relevant to [supported PHP versions](https://secure.php.net/supported-versions.php).
|
|
15
|
+
**If you are using an unsupported version of PHP, please upgrade as soon as possible.**
|
|
16
|
+
|
|
17
|
+
## Important
|
|
18
|
+
|
|
19
|
+
Although this library has been examined by some security experts in the PHP
|
|
20
|
+
community, there will always be a chance that we overlooked something. Please
|
|
21
|
+
ask your favorite trusted hackers to hammer it for implementation errors and
|
|
22
|
+
bugs before even thinking about deploying it in production.
|
|
23
|
+
|
|
24
|
+
**Do not use the master branch, use a [stable release](https://github.com/paragonie/random_compat/releases/latest).**
|
|
25
|
+
|
|
26
|
+
For the background of this library, please refer to our blog post on
|
|
27
|
+
[Generating Random Integers and Strings in PHP](https://paragonie.com/blog/2015/07/how-safely-generate-random-strings-and-integers-in-php).
|
|
28
|
+
|
|
29
|
+
### Usability Notice
|
|
30
|
+
|
|
31
|
+
If PHP cannot safely generate random data, this library will throw an `Exception`.
|
|
32
|
+
It will never fall back to insecure random data. If this keeps happening, upgrade
|
|
33
|
+
to a newer version of PHP immediately.
|
|
34
|
+
|
|
35
|
+
## Installing
|
|
36
|
+
|
|
37
|
+
**With [Composer](https://getcomposer.org):**
|
|
38
|
+
|
|
39
|
+
composer require paragonie/random_compat
|
|
40
|
+
|
|
41
|
+
**Signed PHP Archive:**
|
|
42
|
+
|
|
43
|
+
As of version 1.2.0, we also ship an ECDSA-signed PHP Archive with each stable
|
|
44
|
+
release on Github.
|
|
45
|
+
|
|
46
|
+
1. Download [the `.phar`, `.phar.pubkey`, and `.phar.pubkey.asc`](https://github.com/paragonie/random_compat/releases/latest) files.
|
|
47
|
+
2. (**Recommended** but not required) Verify the PGP signature of `.phar.pubkey`
|
|
48
|
+
(contained within the `.asc` file) using the [PGP public key for Paragon Initiative Enterprises](https://paragonie.com/static/gpg-public-key.txt).
|
|
49
|
+
3. Extract both `.phar` and `.phar.pubkey` files to the same directory.
|
|
50
|
+
4. `require_once "/path/to/random_compat.phar";`
|
|
51
|
+
5. When a new version is released, you only need to replace the `.phar` file;
|
|
52
|
+
the `.pubkey` will not change (unless our signing key is ever compromised).
|
|
53
|
+
|
|
54
|
+
**Manual Installation:**
|
|
55
|
+
|
|
56
|
+
1. Download [a stable release](https://github.com/paragonie/random_compat/releases/latest).
|
|
57
|
+
2. Extract the files into your project.
|
|
58
|
+
3. `require_once "/path/to/random_compat/lib/random.php";`
|
|
59
|
+
|
|
60
|
+
The entrypoint should be **`lib/random.php`** directly, not any of the other files in `/lib`.
|
|
61
|
+
|
|
62
|
+
## Usage
|
|
63
|
+
|
|
64
|
+
This library exposes the [CSPRNG functions added in PHP 7](https://secure.php.net/manual/en/ref.csprng.php)
|
|
65
|
+
for use in PHP 5 projects. Their behavior should be identical.
|
|
66
|
+
|
|
67
|
+
### Generate a string of random bytes
|
|
68
|
+
|
|
69
|
+
```php
|
|
70
|
+
try {
|
|
71
|
+
$string = random_bytes(32);
|
|
72
|
+
} catch (TypeError $e) {
|
|
73
|
+
// Well, it's an integer, so this IS unexpected.
|
|
74
|
+
die("An unexpected error has occurred");
|
|
75
|
+
} catch (Error $e) {
|
|
76
|
+
// This is also unexpected because 32 is a reasonable integer.
|
|
77
|
+
die("An unexpected error has occurred");
|
|
78
|
+
} catch (Exception $e) {
|
|
79
|
+
// If you get this message, the CSPRNG failed hard.
|
|
80
|
+
die("Could not generate a random string. Is our OS secure?");
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
var_dump(bin2hex($string));
|
|
84
|
+
// string(64) "5787c41ae124b3b9363b7825104f8bc8cf27c4c3036573e5f0d4a91ad2eeac6f"
|
|
85
|
+
```
|
|
86
|
+
|
|
87
|
+
### Generate a random integer between two given integers (inclusive)
|
|
88
|
+
|
|
89
|
+
```php
|
|
90
|
+
try {
|
|
91
|
+
$int = random_int(0, 255);
|
|
92
|
+
} catch (TypeError $e) {
|
|
93
|
+
// Well, it's an integer, so this IS unexpected.
|
|
94
|
+
die("An unexpected error has occurred");
|
|
95
|
+
} catch (Error $e) {
|
|
96
|
+
// This is also unexpected because 0 and 255 are both reasonable integers.
|
|
97
|
+
die("An unexpected error has occurred");
|
|
98
|
+
} catch (Exception $e) {
|
|
99
|
+
// If you get this message, the CSPRNG failed hard.
|
|
100
|
+
die("Could not generate a random int. Is our OS secure?");
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
var_dump($int);
|
|
104
|
+
// int(47)
|
|
105
|
+
```
|
|
106
|
+
|
|
107
|
+
### Exception handling
|
|
108
|
+
|
|
109
|
+
When handling exceptions and errors you must account for differences between
|
|
110
|
+
PHP 5 and PHP7.
|
|
111
|
+
|
|
112
|
+
The differences:
|
|
113
|
+
|
|
114
|
+
* Catching `Error` works, so long as it is caught before `Exception`.
|
|
115
|
+
* Catching `Exception` has different behavior, without previously catching `Error`.
|
|
116
|
+
* There is *no* portable way to catch all errors/exceptions.
|
|
117
|
+
|
|
118
|
+
#### Our recommendation
|
|
119
|
+
|
|
120
|
+
**Always** catch `Error` before `Exception`.
|
|
121
|
+
|
|
122
|
+
#### Example
|
|
123
|
+
|
|
124
|
+
```php
|
|
125
|
+
try {
|
|
126
|
+
return random_int(1, $userInput);
|
|
127
|
+
} catch (TypeError $e) {
|
|
128
|
+
// This is okay, so long as `Error` is caught before `Exception`.
|
|
129
|
+
throw new Exception('Please enter a number!');
|
|
130
|
+
} catch (Error $e) {
|
|
131
|
+
// This is required, if you do not need to do anything just rethrow.
|
|
132
|
+
throw $e;
|
|
133
|
+
} catch (Exception $e) {
|
|
134
|
+
// This is optional and maybe omitted if you do not want to handle errors
|
|
135
|
+
// during generation.
|
|
136
|
+
throw new InternalServerErrorException(
|
|
137
|
+
'Oops, our server is bust and cannot generate any random data.',
|
|
138
|
+
500,
|
|
139
|
+
$e
|
|
140
|
+
);
|
|
141
|
+
}
|
|
142
|
+
```
|
|
143
|
+
|
|
144
|
+
### Troubleshooting
|
|
145
|
+
|
|
146
|
+
#### Exception: "Could not gather sufficient random data"**
|
|
147
|
+
|
|
148
|
+
If an Exception is thrown, then your operating system is not secure.
|
|
149
|
+
|
|
150
|
+
1. If you're on Windows, make sure you enable mcrypt.
|
|
151
|
+
2. If you're on any other OS, make sure `/dev/urandom` is readable.
|
|
152
|
+
* FreeBSD jails need to expose `/dev/urandom` from the host OS
|
|
153
|
+
* If you use `open_basedir`, make sure `/dev/urandom` is allowed
|
|
154
|
+
|
|
155
|
+
This library does not (and will not accept any patches to) fall back to
|
|
156
|
+
an insecure random number generator.
|
|
157
|
+
|
|
158
|
+
#### Version Conflict with [Other PHP Project]
|
|
159
|
+
|
|
160
|
+
If you're using a project that has a line like this in its composer.json
|
|
161
|
+
|
|
162
|
+
"require" {
|
|
163
|
+
...
|
|
164
|
+
"paragonie/random_compat": "~1.1",
|
|
165
|
+
...
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
...and then you try to add random_compat 2 (or another library that explicitly
|
|
169
|
+
requires random_compat 2, such as [this secure PHP encryption library](https://github.com/defuse/php-encryption)),
|
|
170
|
+
you will get a version conflict.
|
|
171
|
+
|
|
172
|
+
The solution is to get the project to update its requirement string to allow
|
|
173
|
+
version 2 and above to be used instead of hard-locking users to version 1.
|
|
174
|
+
|
|
175
|
+
```diff
|
|
176
|
+
"require" {
|
|
177
|
+
...
|
|
178
|
+
- "paragonie/random_compat": "~1.1",
|
|
179
|
+
+ "paragonie/random_compat": "^1|^2",
|
|
180
|
+
...
|
|
181
|
+
}
|
|
182
|
+
```
|
|
183
|
+
|
|
184
|
+
## Contributors
|
|
185
|
+
|
|
186
|
+
This project would not be anywhere near as excellent as it is today if it
|
|
187
|
+
weren't for the contributions of the following individuals:
|
|
188
|
+
|
|
189
|
+
* [@AndrewCarterUK (Andrew Carter)](https://github.com/AndrewCarterUK)
|
|
190
|
+
* [@asgrim (James Titcumb)](https://github.com/asgrim)
|
|
191
|
+
* [@bcremer (Benjamin Cremer)](https://github.com/bcremer)
|
|
192
|
+
* [@chriscct7 (Chris Christoff)](https://github.com/chriscct7)
|
|
193
|
+
* [@CodesInChaos (Christian Winnerlein)](https://github.com/CodesInChaos)
|
|
194
|
+
* [@ConnorVG (Connor S. Parks)](https://github.com/ConnorVG)
|
|
195
|
+
* [@cs278 (Chris Smith)](https://github.com/cs278)
|
|
196
|
+
* [@cweagans (Cameron Eagans)](https://github.com/cweagans)
|
|
197
|
+
* [@dd32 (Dion Hulse)](https://github.com/dd32)
|
|
198
|
+
* [@geggleto (Glenn Eggleton)](https://github.com/geggleto)
|
|
199
|
+
* [@glensc (Elan Ruusamäe)](https://github.com/glensc)
|
|
200
|
+
* [@GrahamCampbell (Graham Campbell)](https://github.com/GrahamCampbell)
|
|
201
|
+
* [@ircmaxell (Anthony Ferrara)](https://github.com/ircmaxell)
|
|
202
|
+
* [@jdevalk (Joost de Valk)](https://github.com/jdevalk)
|
|
203
|
+
* [@jedisct1 (Frank Denis)](https://github.com/jedisct1)
|
|
204
|
+
* [@juliangut (Julián Gutiérrez)](https://github.com/juliangut)
|
|
205
|
+
* [@kelunik (Niklas Keller)](https://github.com/kelunik)
|
|
206
|
+
* [@lt (Leigh)](https://github.com/lt)
|
|
207
|
+
* [@MasonM (Mason Malone)](https://github.com/MasonM)
|
|
208
|
+
* [@menkaff (Mehran NikNafs)](https://github.com/menkaff)
|
|
209
|
+
* [@mmeyer2k (Michael M)](https://github.com/mmeyer2k)
|
|
210
|
+
* [@narfbg (Andrey Andreev)](https://github.com/narfbg)
|
|
211
|
+
* [@nicolas-grekas (Nicolas Grekas)](https://github.com/nicolas-grekas)
|
|
212
|
+
* [@ocean90 (Dominik Schilling)](https://github.com/ocean90)
|
|
213
|
+
* [@oittaa](https://github.com/oittaa)
|
|
214
|
+
* [@oucil (Kevin Farley)](https://github.com/oucil)
|
|
215
|
+
* [@philios33 (Phil Nicholls)](https://github.com/philios33)
|
|
216
|
+
* [@redragonx (Stephen Chavez)](https://github.com/redragonx)
|
|
217
|
+
* [@relaxnow (Boy Baukema)](https://github.com/relaxnow)
|
|
218
|
+
* [@rchouinard (Ryan Chouinard)](https://github.com/rchouinard)
|
|
219
|
+
* [@rugk](https://github.com/rugk)
|
|
220
|
+
* [@SammyK (Sammy Kaye Powers)](https://github.com/SammyK)
|
|
221
|
+
* [@scottchiefbaker (Scott Baker)](https://github.com/scottchiefbaker)
|
|
222
|
+
* [@skyosev (Stoyan Kyosev)](https://github.com/skyosev)
|
|
223
|
+
* [@sthen (Stuart Henderseon)](https://github.com/sthen)
|
|
224
|
+
* [@stof (Christophe Coevoet)](https://github.com/stof)
|
|
225
|
+
* [@teohhanhui (Teoh Han Hui)](https://github.com/teohhanhui)
|
|
226
|
+
* [@tom-- (Tom Worster)](https://github.com/tom--)
|
|
227
|
+
* [@tsyr2ko](https://github.com/tsyr2ko)
|
|
228
|
+
* [@trowski (Aaron Piotrowski)](https://github.com/trowski)
|
|
229
|
+
* [@twistor (Chris Lepannen)](https://github.com/twistor)
|
|
230
|
+
* [@vinkla (Vincent Klaiber)](https://github.com/vinkla)
|
|
231
|
+
* [@voku (Lars Moelleken)](https://github.com/voku)
|
|
232
|
+
* [@xabbuh (Christian Flothmann)](https://github.com/xabbuh)
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
# An Invitation to Security Researchers
|
|
2
|
+
|
|
3
|
+
Every company says they take security "very seriously." Rather than bore anyone
|
|
4
|
+
with banal boilerplate, here are some quick answers followed by detailed
|
|
5
|
+
elaboration. If you have any questions about our policies, please email them to
|
|
6
|
+
`scott@paragonie.com`.
|
|
7
|
+
|
|
8
|
+
## Quick Answers
|
|
9
|
+
|
|
10
|
+
* There is no compulsion to disclose vulnerabilities privately, but we
|
|
11
|
+
appreciate a head's up.
|
|
12
|
+
* `security@paragonie.com` will get your reports to the right person. Our GPG
|
|
13
|
+
fingerprint, should you decide to encrypt your report, is
|
|
14
|
+
`7F52 D5C6 1D12 55C7 3136 2E82 6B97 A1C2 8264 04DA`.
|
|
15
|
+
* **YES**, we will reward security researchers who disclose vulnerabilities in
|
|
16
|
+
our software.
|
|
17
|
+
* In most cases, **No Proof-of-Concept Required.**
|
|
18
|
+
* We have a [bug bounty program on HackerOne](https://hackerone.com/paragonie).
|
|
19
|
+
|
|
20
|
+
## How to Report a Security Bug to Paragon Initiative Enterprises
|
|
21
|
+
|
|
22
|
+
### There is no compulsion to disclose privately.
|
|
23
|
+
|
|
24
|
+
We believe vulnerability disclosure style is a personal choice and enjoy working
|
|
25
|
+
with a diverse community. We understand and appreciate the importance of Full
|
|
26
|
+
Disclosure in the history and practice of security research.
|
|
27
|
+
|
|
28
|
+
We would *like* to know about high-severity bugs before they become public
|
|
29
|
+
knowledge, so we can fix them in a timely manner, but **we do not believe in
|
|
30
|
+
threatening researchers or trying to enforce vulnerability embargoes**.
|
|
31
|
+
|
|
32
|
+
Ultimately, if you discover a security-affecting vulnerability, what you do with
|
|
33
|
+
it is your choice. We would like to work with people, and to celebrate and
|
|
34
|
+
reward their skill, experience, and dedication. We appreciate being informed of
|
|
35
|
+
our mistakes so we can learn from them and build a better product. Our goal is
|
|
36
|
+
to empower the community.
|
|
37
|
+
|
|
38
|
+
### Where to Send Security Vulnerabilities
|
|
39
|
+
|
|
40
|
+
Our security email address is `security@paragonie.com`. Also feel free to open a
|
|
41
|
+
new issue on Github if you want to disclose publicly.
|
|
42
|
+
|
|
43
|
+
```
|
|
44
|
+
-----BEGIN PGP PUBLIC KEY BLOCK-----
|
|
45
|
+
Version: GnuPG
|
|
46
|
+
|
|
47
|
+
mQENBFUgwRUBCADcIpqNwyYc5UmY/tpx1sF/rQ3knR1YNXYZThzFV+Gmqhp1fDH5
|
|
48
|
+
qBs9foh1xwI6O7knWmQngnf/nBumI3x6xj7PuOdEZUh2FwCG/VWnglW8rKmoHzHA
|
|
49
|
+
ivjiu9SLnPIPAgHSHeh2XD7q3Ndm3nenbjAiRFNl2iXcwA2cTQp9Mmfw9vVcw0G0
|
|
50
|
+
z1o0G3s8cC8ZS6flFySIervvfSRWj7A1acI5eE3+AH/qXJRdEJ+9J8OB65p1JMfk
|
|
51
|
+
6+fWgOB1XZxMpz70S0rW6IX38WDSRhEK2fXyZJAJjyt+YGuzjZySNSoQR/V6vNYn
|
|
52
|
+
syrNPCJ2i5CgZQxAkyBBcr7koV9RIhPRzct/ABEBAAG0IVNlY3VyaXR5IDxzZWN1
|
|
53
|
+
cml0eUBwYXJhZ29uaWUuY29tPokBOQQTAQIAIwUCVSDBFQIbAwcLCQgHAwIBBhUI
|
|
54
|
+
AgkKCwQWAgMBAh4BAheAAAoJEGuXocKCZATat2YIAIoejNFEQ2c1iaOEtSuB7Pn/
|
|
55
|
+
WLbsDsHNLDKOV+UnfaCjv/vL7D+5NMChFCi2frde/NQb2TsjqmIH+V+XbnJtlrXD
|
|
56
|
+
Vj7yvMVal+Jqjwj7v4eOEWcKVcFZk+9cfUgh7t92T2BMX58RpgZF0IQZ6Z1R3FfC
|
|
57
|
+
9Ub4X6ykW+te1q0/4CoRycniwmlQi6iGSr99LQ5pfJq2Qlmz/luTZ0UX0h575T7d
|
|
58
|
+
cp2T1sX/zFRk/fHeANWSksipdDBjAXR7NMnYZgw2HghEdFk/xRDY7K1NRWNZBf05
|
|
59
|
+
WrMHmh6AIVJiWZvI175URxEe268hh+wThBhXQHMhFNJM1qPIuzb4WogxM3UUD7m5
|
|
60
|
+
AQ0EVSDBFQEIALNkpzSuJsHAHh79sc0AYWztdUe2MzyofQbbOnOCpWZebYsC3EXU
|
|
61
|
+
335fIg59k0m6f+O7GmEZzzIv5v0i99GS1R8CJm6FvhGqtH8ZqmOGbc71WdJSiNVE
|
|
62
|
+
0kpQoJlVzRbig6ZyyjzrggbM1eh5OXOk5pw4+23FFEdw7JWU0HJS2o71r1hwp05Z
|
|
63
|
+
vy21kcUEobz/WWQQyGS0Neo7PJn+9KS6wOxXul/UE0jct/5f7KLMdWMJ1VgniQmm
|
|
64
|
+
hjvkHLPSICteqCI04RfcmMseW9gueHQXeUu1SNIvsWa2MhxjeBej3pDnrZWszKwy
|
|
65
|
+
gF45GO9/v4tkIXNMy5J1AtOyRgQ3IUMqp8EAEQEAAYkBHwQYAQIACQUCVSDBFQIb
|
|
66
|
+
DAAKCRBrl6HCgmQE2jnIB/4/xFz8InpM7eybnBOAir3uGcYfs3DOmaKn7qWVtGzv
|
|
67
|
+
rKpQPYnVtlU2i6Z5UO4c4jDLT/8Xm1UDz3Lxvqt4xCaDwJvBZexU5BMK8l5DvOzH
|
|
68
|
+
6o6P2L1UDu6BvmPXpVZz7/qUhOnyf8VQg/dAtYF4/ax19giNUpI5j5o5mX5w80Rx
|
|
69
|
+
qSXV9NdSL4fdjeG1g/xXv2luhoV53T1bsycI3wjk/x5tV+M2KVhZBvvuOm/zhJje
|
|
70
|
+
oLWp0saaESkGXIXqurj6gZoujJvSvzl0n9F9VwqMEizDUfrXgtD1siQGhP0sVC6q
|
|
71
|
+
ha+F/SAEJ0jEquM4TfKWWU2S5V5vgPPpIQSYRnhQW4b1
|
|
72
|
+
=xJPW
|
|
73
|
+
-----END PGP PUBLIC KEY BLOCK-----
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
### We Will Reward Security Researchers
|
|
77
|
+
|
|
78
|
+
**This process has not been formalized; nor have dollar amounts been
|
|
79
|
+
discussed.**
|
|
80
|
+
|
|
81
|
+
However, if you report a valid security-affecting bug, we will compensate you
|
|
82
|
+
for the time spent finding the vulnerability and reward you for being a good
|
|
83
|
+
neighbor.
|
|
84
|
+
|
|
85
|
+
#### What does a "valid" bug mean?
|
|
86
|
+
|
|
87
|
+
There are two sides to this:
|
|
88
|
+
|
|
89
|
+
1. Some have spammed projects with invalid bug reports hoping to collect
|
|
90
|
+
bounties for pressing a button and running an automated analysis tool. This
|
|
91
|
+
is not cool.
|
|
92
|
+
2. There is a potential for the developers of a project to declare all security
|
|
93
|
+
bug reports as invalid to save money.
|
|
94
|
+
|
|
95
|
+
Our team members have an established history of reporting vulnerabilities to
|
|
96
|
+
large open source projects. **We aren't in the business of ripping people off.**
|
|
97
|
+
When in doubt, our policy is to err on the side of generosity.
|
|
98
|
+
|
|
99
|
+
### No Proof-of-Concept Required
|
|
100
|
+
|
|
101
|
+
We might ask for one if we feel we do not understand some of the details
|
|
102
|
+
pertaining to a specific vulnerability. We certainly appreciate them if you
|
|
103
|
+
include them in your report, but we believe **the burden lies with the developer
|
|
104
|
+
to prove their software *is* secure** rather than with the researcher to prove
|
|
105
|
+
that it isn't.
|
|
106
|
+
|
|
107
|
+
In our experience, most bugs are simpler to fix than they are to exploit.
|
|
108
|
+
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "paragonie/random_compat",
|
|
3
|
+
"description": "PHP 5.x polyfill for random_bytes() and random_int() from PHP 7",
|
|
4
|
+
"keywords": [
|
|
5
|
+
"csprng",
|
|
6
|
+
"random",
|
|
7
|
+
"polyfill",
|
|
8
|
+
"pseudorandom"
|
|
9
|
+
],
|
|
10
|
+
"license": "MIT",
|
|
11
|
+
"type": "library",
|
|
12
|
+
"authors": [
|
|
13
|
+
{
|
|
14
|
+
"name": "Paragon Initiative Enterprises",
|
|
15
|
+
"email": "security@paragonie.com",
|
|
16
|
+
"homepage": "https://paragonie.com"
|
|
17
|
+
}
|
|
18
|
+
],
|
|
19
|
+
"support": {
|
|
20
|
+
"issues": "https://github.com/paragonie/random_compat/issues",
|
|
21
|
+
"email": "info@paragonie.com",
|
|
22
|
+
"source": "https://github.com/paragonie/random_compat"
|
|
23
|
+
},
|
|
24
|
+
"require": {
|
|
25
|
+
"php": ">= 7"
|
|
26
|
+
},
|
|
27
|
+
"require-dev": {
|
|
28
|
+
"vimeo/psalm": "^1",
|
|
29
|
+
"phpunit/phpunit": "4.*|5.*"
|
|
30
|
+
},
|
|
31
|
+
"suggest": {
|
|
32
|
+
"ext-libsodium": "Provides a modern crypto API that can be used to generate random bytes."
|
|
33
|
+
}
|
|
34
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
-----BEGIN PGP SIGNATURE-----
|
|
2
|
+
Version: GnuPG v2.0.22 (MingW32)
|
|
3
|
+
|
|
4
|
+
iQEcBAABAgAGBQJWtW1hAAoJEGuXocKCZATaJf0H+wbZGgskK1dcRTsuVJl9IWip
|
|
5
|
+
QwGw/qIKI280SD6/ckoUMxKDCJiFuPR14zmqnS36k7N5UNPnpdTJTS8T11jttSpg
|
|
6
|
+
1LCmgpbEIpgaTah+cELDqFCav99fS+bEiAL5lWDAHBTE/XPjGVCqeehyPYref4IW
|
|
7
|
+
NDBIEsvnHPHPLsn6X5jq4+Yj5oUixgxaMPiR+bcO4Sh+RzOVB6i2D0upWfRXBFXA
|
|
8
|
+
NNnsg9/zjvoC7ZW73y9uSH+dPJTt/Vgfeiv52/v41XliyzbUyLalf02GNPY+9goV
|
|
9
|
+
JHG1ulEEBJOCiUD9cE1PUIJwHA/HqyhHIvV350YoEFiHl8iSwm7SiZu5kPjaq74=
|
|
10
|
+
=B6+8
|
|
11
|
+
-----END PGP SIGNATURE-----
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
/**
|
|
3
|
+
* Random_* Compatibility Library
|
|
4
|
+
* for using the new PHP 7 random_* API in PHP 5 projects
|
|
5
|
+
*
|
|
6
|
+
* @version 2.99.99
|
|
7
|
+
* @released 2018-06-06
|
|
8
|
+
*
|
|
9
|
+
* The MIT License (MIT)
|
|
10
|
+
*
|
|
11
|
+
* Copyright (c) 2015 - 2018 Paragon Initiative Enterprises
|
|
12
|
+
*
|
|
13
|
+
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
14
|
+
* of this software and associated documentation files (the "Software"), to deal
|
|
15
|
+
* in the Software without restriction, including without limitation the rights
|
|
16
|
+
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
17
|
+
* copies of the Software, and to permit persons to whom the Software is
|
|
18
|
+
* furnished to do so, subject to the following conditions:
|
|
19
|
+
*
|
|
20
|
+
* The above copyright notice and this permission notice shall be included in
|
|
21
|
+
* all copies or substantial portions of the Software.
|
|
22
|
+
*
|
|
23
|
+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
24
|
+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
25
|
+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
26
|
+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
27
|
+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
28
|
+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
29
|
+
* SOFTWARE.
|
|
30
|
+
*/
|
|
31
|
+
|
|
32
|
+
// NOP
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
$dist = dirname(__DIR__).'/dist';
|
|
3
|
+
if (!is_dir($dist)) {
|
|
4
|
+
mkdir($dist, 0755);
|
|
5
|
+
}
|
|
6
|
+
if (file_exists($dist.'/random_compat.phar')) {
|
|
7
|
+
unlink($dist.'/random_compat.phar');
|
|
8
|
+
}
|
|
9
|
+
$phar = new Phar(
|
|
10
|
+
$dist.'/random_compat.phar',
|
|
11
|
+
FilesystemIterator::CURRENT_AS_FILEINFO | \FilesystemIterator::KEY_AS_FILENAME,
|
|
12
|
+
'random_compat.phar'
|
|
13
|
+
);
|
|
14
|
+
rename(
|
|
15
|
+
dirname(__DIR__).'/lib/random.php',
|
|
16
|
+
dirname(__DIR__).'/lib/index.php'
|
|
17
|
+
);
|
|
18
|
+
$phar->buildFromDirectory(dirname(__DIR__).'/lib');
|
|
19
|
+
rename(
|
|
20
|
+
dirname(__DIR__).'/lib/index.php',
|
|
21
|
+
dirname(__DIR__).'/lib/random.php'
|
|
22
|
+
);
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* If we pass an (optional) path to a private key as a second argument, we will
|
|
26
|
+
* sign the Phar with OpenSSL.
|
|
27
|
+
*
|
|
28
|
+
* If you leave this out, it will produce an unsigned .phar!
|
|
29
|
+
*/
|
|
30
|
+
if ($argc > 1) {
|
|
31
|
+
if (!@is_readable($argv[1])) {
|
|
32
|
+
echo 'Could not read the private key file:', $argv[1], "\n";
|
|
33
|
+
exit(255);
|
|
34
|
+
}
|
|
35
|
+
$pkeyFile = file_get_contents($argv[1]);
|
|
36
|
+
|
|
37
|
+
$private = openssl_get_privatekey($pkeyFile);
|
|
38
|
+
if ($private !== false) {
|
|
39
|
+
$pkey = '';
|
|
40
|
+
openssl_pkey_export($private, $pkey);
|
|
41
|
+
$phar->setSignatureAlgorithm(Phar::OPENSSL, $pkey);
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* Save the corresponding public key to the file
|
|
45
|
+
*/
|
|
46
|
+
if (!@is_readable($dist.'/random_compat.phar.pubkey')) {
|
|
47
|
+
$details = openssl_pkey_get_details($private);
|
|
48
|
+
file_put_contents(
|
|
49
|
+
$dist.'/random_compat.phar.pubkey',
|
|
50
|
+
$details['key']
|
|
51
|
+
);
|
|
52
|
+
}
|
|
53
|
+
} else {
|
|
54
|
+
echo 'An error occurred reading the private key from OpenSSL.', "\n";
|
|
55
|
+
exit(255);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
/**
|
|
3
|
+
* Class COM
|
|
4
|
+
*
|
|
5
|
+
* This is just a stub class.
|
|
6
|
+
*/
|
|
7
|
+
class COM
|
|
8
|
+
{
|
|
9
|
+
/**
|
|
10
|
+
* This is just a dummy function to make IDE autocomplete less insane.
|
|
11
|
+
*
|
|
12
|
+
* @param int $bytes
|
|
13
|
+
* @param int $dummy
|
|
14
|
+
* @return string
|
|
15
|
+
*/
|
|
16
|
+
public function GetRandom($bytes, $dummy)
|
|
17
|
+
{
|
|
18
|
+
return '';
|
|
19
|
+
}
|
|
20
|
+
}
|